1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 |
- from __future__ import print_function
- import sys
- import argparse
- from io import open
- parser = argparse.ArgumentParser()
- parser.add_argument('statuscodes', help='path/to/Opc.Ua.NodeIds.csv')
- parser.add_argument('outfile', help='outfile w/o extension')
- parser.add_argument('namespace', help='NS0')
- args = parser.parse_args()
- rows = []
- with open(args.statuscodes, mode="rt") as f:
- lines = f.readlines()
- for l in lines:
- rows.append(tuple(l.strip().split(',')))
- fh = open(args.outfile + ".h", "wt", encoding='utf8')
- def printh(string):
- print(string, end=u'\n', file=fh)
- printh(u'''/*---------------------------------------------------------
- * Autogenerated -- do not modify
- * Generated from {0} with script {1}
- *-------------------------------------------------------*/
- #ifndef UA_NODEIDS_{2}_H_
- #define UA_NODEIDS_{2}_H_
- /**
- * Namespace Zero NodeIds
- * ----------------------
- * Numeric identifiers of standard-defined nodes in namespace zero. The
- * following definitions are autogenerated from the ``{0}`` file */
- '''.format(args.statuscodes, sys.argv[0], args.namespace))
- for row in rows:
- printh(u"#define UA_{namespace}ID_{name} {id} /* {description} */".format(namespace=args.namespace, name=row[0].upper(), id=row[1], description=row[2]))
- printh(u'''#endif /* UA_NODEIDS_{0}_H_ */ '''.format(args.namespace))
- fh.close()
|