Как я могу скомпилировать пример XML-файла из учебника Open62541? - PullRequest
1 голос
/ 29 мая 2019

Я нахожусь в главе 11 официального руководства по библиотеке open62541 .HTML-версия здесь .Прежде чем пробовать что-то нестандартное, я просто хочу опробовать эту функцию самым простым способом, «скомпилировав» их пример XML-файла в код C, который затем можно скомпилировать с GCC и запустить как сервер OPC.(Если вы хотите продолжить, загрузите полный исходный код с главной страницы - там есть инструмент компилятора набора узлов.)

Я нахожусь в среде на основе Debian (только CLI).Я сделал копию myNS.xml и сохранил ее непосредственно по пути ~ / code / open62541-open62541-6249bb2 / tools / nodeset_compiler / , который также является моим текущим рабочим каталогом в этом примере.Я попытался использовать компилятор набора узлов с той же самой командой, которую они использовали в учебнике: python ./nodeset_compiler.py --types-array = UA_TYPES --existing ../../deps/ua-nodeset/Schema / Opc.Ua.NodeSet2.xml --xml myNS.xml myNS

Я получаю следующее сообщение об ошибке:

Traceback (most recent call last):
  File "./nodeset_compiler.py", line 126, in <module>
    ns.addNodeSet(xmlfile, True, typesArray=getTypesArray(nsCount))
  File "/root/code/open62541-open62541-6249bb2/tools/nodeset_compiler/nodeset.py", line 224, in addNodeSet
    nodesets = dom.parseString(fileContent).getElementsByTagName("UANodeSet")
  File "/usr/lib/python2.7/xml/dom/minidom.py", line 1928, in parseString
    return expatbuilder.parseString(string)
  File "/usr/lib/python2.7/xml/dom/expatbuilder.py", line 940, in parseString
    return builder.parseString(string)
  File "/usr/lib/python2.7/xml/dom/expatbuilder.py", line 223, in parseString
    parser.Parse(string, True)
xml.parsers.expat.ExpatError: syntax error: line 1, column 0

Любая идея, что я могу делать неправильно?

ОБНОВЛЕНИЕ:

Хорошо, я обнаружил, что есть проблема с моим файлом Opc.Ua.NodeSet2.xml, которую я исправил.Если вы подписаны и хотите получить версию имеющегося у меня файла, вы можете получить ее здесь .

Но теперь у меня есть эта проблема:

INFO:__main__:Preprocessing (existing) ../../deps/ua-nodeset/Schema/Opc.Ua.NodeSet2.xml
INFO:__main__:Preprocessing myNS.xml
Traceback (most recent call last):
  File "./nodeset_compiler.py", line 178, in <module>
    ns.allocateVariables()
  File "/root/code/open62541-open62541-6249bb2/tools/nodeset_compiler/nodeset.py", line 322, in allocateVariables
    n.allocateValue(self)
  File "/root/code/open62541-open62541-6249bb2/tools/nodeset_compiler/nodes.py", line 291, in allocateValue
    self.value.parseXMLEncoding(self.xmlValueDef, dataTypeNode, self)
  File "/root/code/open62541-open62541-6249bb2/tools/nodeset_compiler/datatypes.py", line 161, in parseXMLEncoding
    val = self.__parseXMLSingleValue(el, parentDataTypeNode, parent)
  File "/root/code/open62541-open62541-6249bb2/tools/nodeset_compiler/datatypes.py", line 281, in __parseXMLSingleValue
    extobj.value.append(extobj.__parseXMLSingleValue(ebodypart, parentDataTypeNode, parent, alias=None, encodingPart=e))
  File "/root/code/open62541-open62541-6249bb2/tools/nodeset_compiler/datatypes.py", line 223, in __parseXMLSingleValue
    alias=alias, encodingPart=enc[1], valueRank=enc[2] if len(enc)>2 else None)
  File "/root/code/open62541-open62541-6249bb2/tools/nodeset_compiler/datatypes.py", line 198, in __parseXMLSingleValue
    t.parseXML(xmlvalue)
  File "/root/code/open62541-open62541-6249bb2/tools/nodeset_compiler/datatypes.py", line 330, in parseXML
    self.value = int(unicode(xmlvalue.firstChild.data))
ValueError: invalid literal for int() with base 10: ''

UPDATE_2:

Я попытался сделать то же самое на моем ноутбуке с Windows, и вот ошибка, которую я получил:

INFO:__main__:Preprocessing (existing) ../../deps/ua-nodeset/Schema/Opc.Ua.NodeSet2.xml
INFO:__main__:Preprocessing myNS.xml
Traceback (most recent call last):
  File "./nodeset_compiler.py", line 178, in <module>
    ns.allocateVariables()
  File "C:\Users\ekstraaa\Source\open62541\open62541-open62541-6249bb2\tools\nodeset_compiler\nodeset.py", line 322, in allocateVariables
    n.allocateValue(self)
  File "C:\Users\ekstraaa\Source\open62541\open62541-open62541-6249bb2\tools\nodeset_compiler\nodes.py", line 291, in allocateValue
    self.value.parseXMLEncoding(self.xmlValueDef, dataTypeNode, self)
  File "C:\Users\ekstraaa\Source\open62541\open62541-open62541-6249bb2\tools\nodeset_compiler\datatypes.py", line 161, in parseXMLEncoding
    val = self.__parseXMLSingleValue(el, parentDataTypeNode, parent)
  File "C:\Users\ekstraaa\Source\open62541\open62541-open62541-6249bb2\tools\nodeset_compiler\datatypes.py", line 281, in __parseXMLSingleValue
    extobj.value.append(extobj.__parseXMLSingleValue(ebodypart, parentDataTypeNode, parent, alias=None, encodingPart=e))
  File "C:\Users\ekstraaa\Source\open62541\open62541-open62541-6249bb2\tools\nodeset_compiler\datatypes.py", line 223, in __parseXMLSingleValue
    alias=alias, encodingPart=enc[1], valueRank=enc[2] if len(enc)>2 else None)
  File "C:\Users\ekstraaa\Source\open62541\open62541-open62541-6249bb2\tools\nodeset_compiler\datatypes.py", line 198, in __parseXMLSingleValue
    t.parseXML(xmlvalue)
  File "C:\Users\ekstraaa\Source\open62541\open62541-open62541-6249bb2\tools\nodeset_compiler\datatypes.py", line 330, in parseXML
    self.value = int(unicode(xmlvalue.firstChild.data))
ValueError: invalid literal for int() with base 10: '\n                '

1 Ответ

0 голосов
/ 03 июня 2019

Полная документация для компилятора набора узлов open62541 может быть найдена здесь:

https://open62541.org/doc/current/nodeset_compiler.html

Команда, которую вы используете, также кажется подходящей.

Последняяпроблема, которую вы описываете invalid literal for int(), связана с символом новой строки внутри тега значения переменной.

Это будет исправлено с помощью https://github.com/open62541/open62541/pull/2768

В качестве обходного пути вы можете изменить свой .xml с

<Value>            
    <Int32>
    </Int32>
</Value>

до (без перевода строки):

<Value>            
    <Int32></Int32>
</Value>
...