ua_basictypes.h 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434
  1. #ifndef OPCUA_BASICTYPES_H_
  2. #define OPCUA_BASICTYPES_H_
  3. #include "ua_types.h"
  4. #include "ua_list.h"
  5. /* Stop decoding at the first failure. Free members that were already allocated.
  6. It is assumed that retval is already defined. */
  7. #define CHECKED_DECODE(DECODE, CLEAN_UP) do { \
  8. retval |= DECODE; \
  9. if(retval != UA_SUCCESS) { \
  10. CLEAN_UP; \
  11. return retval; \
  12. } } while(0) \
  13. /* Array operations */
  14. UA_Int32 UA_Array_calcSize(UA_Int32 noElements, UA_Int32 type, void const * const * ptr);
  15. UA_Int32 UA_Array_encodeBinary(void const * const *src, UA_Int32 noElements, UA_Int32 type, UA_Int32* pos, UA_ByteString * dst);
  16. UA_Int32 UA_Array_decodeBinary(UA_ByteString const * src,UA_Int32 noElements, UA_Int32 type, UA_Int32* pos, void *** dst);
  17. UA_Int32 UA_Array_delete(void ***p,UA_Int32 noElements, UA_Int32 type);
  18. UA_Int32 UA_Array_init(void **p,UA_Int32 noElements, UA_Int32 type);
  19. UA_Int32 UA_Array_new(void ***p,UA_Int32 noElements, UA_Int32 type);
  20. UA_Int32 UA_Array_copy(void const * const *src,UA_Int32 noElements, UA_Int32 type, void ***dst);
  21. /* XML preliminaries */
  22. struct XML_Stack;
  23. typedef char const * const XML_Attr;
  24. typedef char const * cstring;
  25. #define XML_STACK_MAX_DEPTH 10
  26. #define XML_STACK_MAX_CHILDREN 40
  27. typedef UA_Int32 (*XML_decoder)(struct XML_Stack* s, XML_Attr* attr, void* dst, UA_Boolean isStart);
  28. #define UA_TYPE_METHOD_PROTOTYPES(TYPE) \
  29. UA_Int32 TYPE##_calcSize(TYPE const * ptr); \
  30. UA_Int32 TYPE##_encodeBinary(TYPE const * src, UA_Int32* pos, UA_ByteString * dst); \
  31. UA_Int32 TYPE##_decodeBinary(UA_ByteString const * src, UA_Int32* pos, TYPE * dst); \
  32. UA_Int32 TYPE##_decodeXML(struct XML_Stack* s, XML_Attr* attr, TYPE* dst, UA_Boolean isStart); \
  33. UA_Int32 TYPE##_delete(TYPE * p); \
  34. UA_Int32 TYPE##_deleteMembers(TYPE * p); \
  35. UA_Int32 TYPE##_init(TYPE * p); \
  36. UA_Int32 TYPE##_new(TYPE ** p); \
  37. UA_Int32 TYPE##_copy(TYPE const *src, TYPE *dst);
  38. #define UA_TYPE_METHOD_CALCSIZE_SIZEOF(TYPE) \
  39. UA_Int32 TYPE##_calcSize(TYPE const * p) { return sizeof(TYPE); }
  40. #define UA_TYPE_METHOD_CALCSIZE_AS(TYPE, TYPE_AS) \
  41. UA_Int32 TYPE##_calcSize(TYPE const * p) { return TYPE_AS##_calcSize((TYPE_AS*) p); }
  42. #define UA_TYPE_METHOD_DELETE_FREE(TYPE) \
  43. UA_Int32 TYPE##_delete(TYPE * p) { return UA_free(p); }
  44. #define UA_TYPE_METHOD_DELETE_AS(TYPE, TYPE_AS) \
  45. UA_Int32 TYPE##_delete(TYPE * p) { return TYPE_AS##_delete((TYPE_AS*) p);}
  46. #define UA_TYPE_METHOD_DELETE_STRUCT(TYPE) \
  47. UA_Int32 TYPE##_delete(TYPE *p) { \
  48. UA_Int32 retval = UA_SUCCESS; \
  49. retval |= TYPE##_deleteMembers(p); \
  50. retval |= UA_free(p); \
  51. return retval; \
  52. }
  53. #define UA_TYPE_METHOD_COPY(TYPE) \
  54. UA_Int32 TYPE##_copy(TYPE const *src, TYPE *dst) { \
  55. UA_Int32 retval = UA_SUCCESS; \
  56. retval |= UA_memcpy(dst, src, TYPE##_calcSize(UA_NULL)); \
  57. return retval; \
  58. }
  59. #define UA_TYPE_METHOD_DELETEMEMBERS_NOACTION(TYPE) \
  60. UA_Int32 TYPE##_deleteMembers(TYPE * p) { return UA_SUCCESS; }
  61. #define UA_TYPE_METHOD_DELETEMEMBERS_AS(TYPE, TYPE_AS) \
  62. UA_Int32 TYPE##_deleteMembers(TYPE * p) { return TYPE_AS##_deleteMembers((TYPE_AS*) p);}
  63. #define UA_TYPE_METHOD_DECODEBINARY_AS(TYPE,TYPE_AS) \
  64. UA_Int32 TYPE##_decodeBinary(UA_ByteString const * src, UA_Int32* pos, TYPE *dst) { \
  65. return TYPE_AS##_decodeBinary(src,pos,(TYPE_AS*) dst); \
  66. }
  67. #define UA_TYPE_METHOD_DECODEXML_NOTIMPL(TYPE) \
  68. UA_Int32 TYPE##_decodeXML(XML_Stack* s, XML_Attr* attr, TYPE* dst, _Bool isStart) { \
  69. DBG_VERBOSE(printf(#TYPE "_decodeXML entered with dst=%p,isStart=%d\n", (void* ) dst, isStart)); \
  70. return UA_ERR_NOT_IMPLEMENTED;\
  71. }
  72. #define UA_TYPE_METHOD_DECODEXML_AS(TYPE,TYPE_AS) \
  73. UA_Int32 TYPE##_decodeXML(struct XML_Stack* s, XML_Attr* attr, TYPE* dst, _Bool isStart) { \
  74. return TYPE_AS##_decodeXML(s,attr,(TYPE_AS*) dst,isStart); \
  75. }
  76. #define UA_TYPE_METHOD_ENCODEBINARY_AS(TYPE,TYPE_AS) \
  77. UA_Int32 TYPE##_encodeBinary(TYPE const * src, UA_Int32* pos, UA_ByteString *dst) { \
  78. return TYPE_AS##_encodeBinary((TYPE_AS*) src,pos,dst); \
  79. }
  80. #define UA_TYPE_METHOD_INIT_AS(TYPE, TYPE_AS) \
  81. UA_Int32 TYPE##_init(TYPE * p) { \
  82. return TYPE_AS##_init((TYPE_AS*)p); \
  83. }
  84. #define UA_TYPE_METHOD_COPY_AS(TYPE, TYPE_AS) \
  85. UA_Int32 TYPE##_copy(TYPE const *src, TYPE *dst) {return TYPE_AS##_copy((TYPE_AS*) src,(TYPE_AS*)dst); \
  86. }
  87. #define UA_TYPE_METHOD_PROTOTYPES_AS_WOXML(TYPE, TYPE_AS) \
  88. UA_TYPE_METHOD_CALCSIZE_AS(TYPE, TYPE_AS) \
  89. UA_TYPE_METHOD_ENCODEBINARY_AS(TYPE, TYPE_AS) \
  90. UA_TYPE_METHOD_DECODEBINARY_AS(TYPE, TYPE_AS) \
  91. UA_TYPE_METHOD_DELETE_AS(TYPE, TYPE_AS) \
  92. UA_TYPE_METHOD_DELETEMEMBERS_AS(TYPE, TYPE_AS) \
  93. UA_TYPE_METHOD_INIT_AS(TYPE, TYPE_AS) \
  94. UA_TYPE_METHOD_COPY_AS(TYPE, TYPE_AS)
  95. #define UA_TYPE_METHOD_PROTOTYPES_AS(TYPE, TYPE_AS) \
  96. UA_TYPE_METHOD_PROTOTYPES_AS_WOXML(TYPE, TYPE_AS) \
  97. UA_TYPE_METHOD_DECODEXML_AS(TYPE, TYPE_AS)
  98. #define UA_TYPE_METHOD_NEW_DEFAULT(TYPE) \
  99. UA_Int32 TYPE##_new(TYPE ** p) { \
  100. UA_Int32 retval = UA_SUCCESS;\
  101. retval |= UA_alloc((void**)p, TYPE##_calcSize(UA_NULL));\
  102. retval |= TYPE##_init(*p);\
  103. return retval;\
  104. }
  105. #define UA_TYPE_METHOD_INIT_DEFAULT(TYPE) \
  106. UA_Int32 TYPE##_init(TYPE * p) { \
  107. if(p==UA_NULL)return UA_ERROR;\
  108. *p = (TYPE)0;\
  109. return UA_SUCCESS;\
  110. }
  111. //#define UA_TYPE_COPY_METHOD_PROTOTYPE(TYPE) \ UA_Int32 TYPE##_copy(TYPE const *src, TYPE *dst);
  112. /*** Prototypes for basic types **/
  113. UA_TYPE_METHOD_PROTOTYPES (UA_Boolean)
  114. UA_TYPE_METHOD_PROTOTYPES (UA_Byte)
  115. UA_TYPE_METHOD_PROTOTYPES (UA_SByte)
  116. UA_TYPE_METHOD_PROTOTYPES (UA_Int16)
  117. UA_TYPE_METHOD_PROTOTYPES (UA_UInt16)
  118. UA_TYPE_METHOD_PROTOTYPES (UA_Int32)
  119. UA_TYPE_METHOD_PROTOTYPES (UA_UInt32)
  120. UA_TYPE_METHOD_PROTOTYPES (UA_Int64)
  121. UA_TYPE_METHOD_PROTOTYPES (UA_UInt64)
  122. UA_TYPE_METHOD_PROTOTYPES (UA_Float)
  123. UA_TYPE_METHOD_PROTOTYPES (UA_Double)
  124. /**
  125. * StatusCodeBinaryEncoding
  126. * Part: 6
  127. * Chapter: 5.2.2.11
  128. * Page: 20
  129. *
  130. * StatusCodes aren't an enum (=int), since 32 unsigned bits are needed.
  131. * See also ua_statuscodes.h
  132. */
  133. typedef UA_UInt32 UA_StatusCode;
  134. UA_TYPE_METHOD_PROTOTYPES (UA_StatusCode)
  135. /** IntegerId - Part: 4, Chapter: 7.13, Page: 118 */
  136. typedef float UA_IntegerId;
  137. UA_TYPE_METHOD_PROTOTYPES (UA_IntegerId)
  138. /** @brief String Object
  139. *
  140. * String - Part: 6, Chapter: 5.2.2.4, Page: 16
  141. */
  142. typedef struct UA_String {
  143. UA_Int32 length;
  144. UA_Byte* data;
  145. } UA_String;
  146. UA_TYPE_METHOD_PROTOTYPES (UA_String)
  147. //UA_Int32 UA_String_copy(UA_String const * src, UA_String* dst);
  148. UA_Int32 UA_String_copycstring(char const * src, UA_String* dst);
  149. UA_Int32 UA_String_copyprintf(char const * fmt, UA_String* dst, ...);
  150. UA_Int32 UA_String_compare(const UA_String *string1, const UA_String *string2);
  151. void UA_String_printf(char const * label, const UA_String* string);
  152. void UA_String_printx(char const * label, const UA_String* string);
  153. void UA_String_printx_hex(char const * label, const UA_String* string);
  154. /* ByteString - Part: 6, Chapter: 5.2.2.7, Page: 17 */
  155. UA_TYPE_METHOD_PROTOTYPES (UA_ByteString)
  156. UA_Int32 UA_ByteString_compare(const UA_ByteString *string1, const UA_ByteString *string2);
  157. //UA_Int32 UA_ByteString_copy(UA_ByteString const * src, UA_ByteString* dst);
  158. UA_Int32 UA_ByteString_newMembers(UA_ByteString* p, UA_Int32 length);
  159. extern UA_ByteString UA_ByteString_securityPoliceNone;
  160. /* LocalizedTextBinaryEncoding - Part: 6, Chapter: 5.2.2.14, Page: 21 */
  161. enum UA_LOCALIZEDTEXT_ENCODINGMASKTYPE_enum {
  162. UA_LOCALIZEDTEXT_ENCODINGMASKTYPE_LOCALE = 0x01,
  163. UA_LOCALIZEDTEXT_ENCODINGMASKTYPE_TEXT = 0x02
  164. };
  165. typedef struct UA_LocalizedText {
  166. UA_Byte encodingMask;
  167. UA_String locale;
  168. UA_String text;
  169. } UA_LocalizedText;
  170. UA_TYPE_METHOD_PROTOTYPES (UA_LocalizedText)
  171. UA_Int32 UA_LocalizedText_copycstring(char const * src, UA_LocalizedText* dst);
  172. void UA_ByteString_printf(char* label, const UA_ByteString* string);
  173. void UA_ByteString_printx(char* label, const UA_ByteString* string);
  174. void UA_ByteString_printx_hex(char* label, const UA_ByteString* string);
  175. /* GuidType - Part: 6, Chapter: 5.2.2.6 Page: 17 */
  176. typedef struct UA_Guid {
  177. UA_UInt32 data1;
  178. UA_UInt16 data2;
  179. UA_UInt16 data3;
  180. UA_Byte data4[8];
  181. } UA_Guid;
  182. UA_TYPE_METHOD_PROTOTYPES (UA_Guid)
  183. UA_Int32 UA_Guid_compare(const UA_Guid *g1, const UA_Guid *g2);
  184. /* DateTime - Part: 6, Chapter: 5.2.2.5, Page: 16 */
  185. typedef UA_Int64 UA_DateTime; //100 nanosecond resolution
  186. UA_TYPE_METHOD_PROTOTYPES (UA_DateTime)
  187. UA_DateTime UA_DateTime_now();
  188. typedef struct UA_DateTimeStruct {
  189. UA_Int16 nanoSec;
  190. UA_Int16 microSec;
  191. UA_Int16 milliSec;
  192. UA_Int16 sec;
  193. UA_Int16 min;
  194. UA_Int16 hour;
  195. UA_Int16 day;
  196. UA_Int16 mounth;
  197. UA_Int16 year;
  198. } UA_DateTimeStruct;
  199. UA_DateTimeStruct UA_DateTime_toStruct(UA_DateTime time);
  200. UA_Int32 UA_DateTime_toString(UA_DateTime time, UA_String* timeString);
  201. typedef struct UA_NodeId {
  202. UA_Byte encodingByte; //enum BID_NodeIdEncodingValuesType
  203. UA_UInt16 namespace;
  204. union {
  205. UA_UInt32 numeric;
  206. UA_String string;
  207. UA_Guid guid;
  208. UA_ByteString byteString;
  209. } identifier;
  210. } UA_NodeId;
  211. UA_TYPE_METHOD_PROTOTYPES (UA_NodeId)
  212. UA_Int32 UA_NodeId_compare(const UA_NodeId *n1, const UA_NodeId *n2);
  213. void UA_NodeId_printf(char* label, const UA_NodeId* node);
  214. UA_Boolean UA_NodeId_isNull(const UA_NodeId* p);
  215. UA_Int16 UA_NodeId_getNamespace(UA_NodeId const * id);
  216. UA_Int16 UA_NodeId_getIdentifier(UA_NodeId const * id);
  217. _Bool UA_NodeId_isBasicType(UA_NodeId const * id);
  218. /* XmlElement - Part: 6, Chapter: 5.2.2.8, Page: 17 */
  219. typedef struct UA_XmlElement {
  220. //TODO Überlegung ob man es direkt als ByteString speichert oder als String
  221. UA_ByteString data;
  222. } UA_XmlElement;
  223. UA_TYPE_METHOD_PROTOTYPES (UA_XmlElement)
  224. /* ExpandedNodeId - Part: 6, Chapter: 5.2.2.10, Page: 19 */
  225. // 62541-6 Chapter 5.2.2.9, Table 5
  226. #define UA_NODEIDTYPE_NAMESPACE_URI_FLAG 0x80
  227. #define UA_NODEIDTYPE_SERVERINDEX_FLAG 0x40
  228. #define UA_NODEIDTYPE_MASK (~(UA_NODEIDTYPE_NAMESPACE_URI_FLAG | UA_NODEIDTYPE_SERVERINDEX_FLAG))
  229. typedef struct UA_ExpandedNodeId {
  230. UA_NodeId nodeId;
  231. UA_String namespaceUri;
  232. UA_UInt32 serverIndex;
  233. } UA_ExpandedNodeId;
  234. UA_TYPE_METHOD_PROTOTYPES(UA_ExpandedNodeId)
  235. UA_Boolean UA_ExpandedNodeId_isNull(const UA_ExpandedNodeId* p);
  236. /* IdentifierType */
  237. typedef UA_Int32 UA_IdentifierType;
  238. UA_TYPE_METHOD_PROTOTYPES(UA_IdentifierType)
  239. /* ExtensionObjectBinaryEncoding - Part: 6, Chapter: 5.2.2.15, Page: 21 */
  240. typedef struct UA_ExtensionObject {
  241. UA_NodeId typeId;
  242. UA_Byte encoding; //Type of the enum UA_ExtensionObjectEncodingMaskType
  243. UA_ByteString body; // contains either the bytestring or a pointer to the memory-object
  244. } UA_ExtensionObject;
  245. UA_TYPE_METHOD_PROTOTYPES(UA_ExtensionObject)
  246. enum UA_ExtensionObject_EncodingMaskType_enum {
  247. UA_EXTENSIONOBJECT_ENCODINGMASK_NOBODYISENCODED = 0x00,
  248. UA_EXTENSIONOBJECT_ENCODINGMASK_BODYISBYTESTRING = 0x01,
  249. UA_EXTENSIONOBJECT_ENCODINGMASK_BODYISXML = 0x02
  250. };
  251. /* QualifiedNameBinaryEncoding - Part: 6, Chapter: 5.2.2.13, Page: 20 */
  252. typedef struct UA_QualifiedName {
  253. UA_UInt16 namespaceIndex;
  254. /*UA_UInt16 reserved; removed by Sten since unclear origin*/
  255. UA_String name;
  256. } UA_QualifiedName;
  257. UA_TYPE_METHOD_PROTOTYPES(UA_QualifiedName)
  258. /* XML Decoding */
  259. /** @brief A readable shortcut for NodeIds. A list of aliases is intensively used in the namespace0-xml-files */
  260. typedef struct UA_NodeSetAlias {
  261. UA_String alias;
  262. UA_String value;
  263. } UA_NodeSetAlias;
  264. UA_TYPE_METHOD_PROTOTYPES (UA_NodeSetAlias)
  265. /** @brief UA_NodeSetAliases - a list of aliases */
  266. typedef struct UA_NodeSetAliases {
  267. UA_Int32 size;
  268. UA_NodeSetAlias** aliases;
  269. } UA_NodeSetAliases;
  270. UA_TYPE_METHOD_PROTOTYPES (UA_NodeSetAliases)
  271. typedef struct XML_child {
  272. cstring name;
  273. UA_Int32 length;
  274. UA_Int32 type;
  275. XML_decoder elementHandler;
  276. void* obj;
  277. } XML_child;
  278. typedef struct XML_Parent {
  279. cstring name;
  280. int textAttribIdx; // -1 - not set
  281. cstring textAttrib;
  282. int activeChild; // -1 - no active child
  283. int totalGatherLength;
  284. UA_list_List textGatherList;
  285. int len; // -1 - empty set
  286. XML_child children[XML_STACK_MAX_CHILDREN];
  287. } XML_Parent;
  288. typedef struct XML_Stack {
  289. int depth;
  290. XML_Parent parent[XML_STACK_MAX_DEPTH];
  291. UA_Int32 nsid;
  292. UA_NodeSetAliases* aliases; // shall point to the aliases of the NodeSet after reading
  293. } XML_Stack;
  294. typedef struct UA_VTable {
  295. UA_UInt32 ns0Id;
  296. UA_Int32 (*calcSize)(void const * ptr);
  297. UA_Int32 (*decodeBinary)(UA_ByteString const * src, UA_Int32* pos, void* dst);
  298. UA_Int32 (*encodeBinary)(void const * src, UA_Int32* pos, UA_ByteString* dst);
  299. UA_Int32 (*decodeXML)(XML_Stack* s, XML_Attr* attr, void* dst, UA_Boolean isStart);
  300. UA_Int32 (*init)(void * p);
  301. UA_Int32 (*new)(void ** p);
  302. UA_Int32 (*copy)(void const *src,void *dst);
  303. UA_Int32 (*delete)(void * p);
  304. UA_UInt32 memSize; // size of the struct only in memory (no dynamic components)
  305. UA_Byte* name;
  306. } UA_VTable;
  307. /* VariantBinaryEncoding - Part: 6, Chapter: 5.2.2.16, Page: 22 */
  308. enum UA_VARIANT_ENCODINGMASKTYPE_enum {
  309. UA_VARIANT_ENCODINGMASKTYPE_TYPEID_MASK = 0x3F, // bits 0:5
  310. UA_VARIANT_ENCODINGMASKTYPE_DIMENSIONS = (0x01 << 6), // bit 6
  311. UA_VARIANT_ENCODINGMASKTYPE_ARRAY = (0x01 << 7) // bit 7
  312. };
  313. typedef struct UA_Variant {
  314. UA_VTable* vt; // internal entry into vTable
  315. UA_Byte encodingMask; // Type of UA_Variant_EncodingMaskType_enum
  316. UA_Int32 arrayLength; // total number of elements
  317. UA_Int32 arrayDimensionsLength;
  318. UA_Int32 **arrayDimensions;
  319. void** data;
  320. } UA_Variant;
  321. UA_TYPE_METHOD_PROTOTYPES (UA_Variant)
  322. UA_Int32 UA_Variant_copySetValue(UA_Variant *v, UA_Int32 type, const void* data);
  323. UA_Int32 UA_Variant_copySetArray(UA_Variant *v, UA_Int32 type_id, UA_Int32 arrayLength, UA_UInt32 elementSize, const void* array);
  324. /**
  325. @brief Functions UA_Variant_borrowSetValue and ..Array allow to define
  326. variants whose payload will not be deleted. This is achieved by a second
  327. vtable. The functionality can be used e.g. when UA_VariableNodes point into a
  328. "father" structured object that is stored in an UA_VariableNode itself. */
  329. UA_Int32 UA_Variant_borrowSetValue(UA_Variant *v, UA_Int32 type, const void* data); // Take care not to free the data before the variant.
  330. UA_Int32 UA_Variant_borrowSetArray(UA_Variant *v, UA_Int32 type, UA_Int32 arrayLength, const void* data); // Take care not to free the data before the variant.
  331. /* DataValue - Part: 6, Chapter: 5.2.2.17, Page: 23 */
  332. typedef struct UA_DataValue {
  333. UA_Byte encodingMask;
  334. UA_Variant value;
  335. UA_StatusCode status;
  336. UA_DateTime sourceTimestamp;
  337. UA_Int16 sourcePicoseconds;
  338. UA_DateTime serverTimestamp;
  339. UA_Int16 serverPicoseconds;
  340. } UA_DataValue;
  341. UA_TYPE_METHOD_PROTOTYPES(UA_DataValue)
  342. /** 62541-6, §5.2.2.17, Table 15 */
  343. enum UA_DATAVALUE_ENCODINGMASKTYPE_enum {
  344. UA_DATAVALUE_ENCODINGMASK_VARIANT = 0x01,
  345. UA_DATAVALUE_ENCODINGMASK_STATUSCODE = 0x02,
  346. UA_DATAVALUE_ENCODINGMASK_SOURCETIMESTAMP = 0x04,
  347. UA_DATAVALUE_ENCODINGMASK_SERVERTIMESTAMP = 0x08,
  348. UA_DATAVALUE_ENCODINGMASK_SOURCEPICOSECONDS = 0x10,
  349. UA_DATAVALUE_ENCODINGMASK_SERVERPICOSECONDS = 0x20
  350. };
  351. /* DiagnosticInfo - Part: 6, Chapter: 5.2.2.12, Page: 20 */
  352. typedef struct UA_DiagnosticInfo {
  353. UA_Byte encodingMask; //Type of the Enum UA_DIAGNOSTICINFO_ENCODINGMASKTYPE
  354. UA_Int32 symbolicId;
  355. UA_Int32 namespaceUri;
  356. UA_Int32 localizedText;
  357. UA_Int32 locale;
  358. UA_String additionalInfo;
  359. UA_StatusCode innerStatusCode;
  360. struct UA_DiagnosticInfo* innerDiagnosticInfo;
  361. } UA_DiagnosticInfo;
  362. UA_TYPE_METHOD_PROTOTYPES(UA_DiagnosticInfo)
  363. enum UA_DIAGNOSTICINFO_ENCODINGMASKTYPE_enum {
  364. UA_DIAGNOSTICINFO_ENCODINGMASK_SYMBOLICID = 0x01,
  365. UA_DIAGNOSTICINFO_ENCODINGMASK_NAMESPACE = 0x02,
  366. UA_DIAGNOSTICINFO_ENCODINGMASK_LOCALIZEDTEXT = 0x04,
  367. UA_DIAGNOSTICINFO_ENCODINGMASK_LOCALE = 0x08,
  368. UA_DIAGNOSTICINFO_ENCODINGMASK_ADDITIONALINFO = 0x10,
  369. UA_DIAGNOSTICINFO_ENCODINGMASK_INNERSTATUSCODE = 0x20,
  370. UA_DIAGNOSTICINFO_ENCODINGMASK_INNERDIAGNOSTICINFO = 0x40
  371. };
  372. typedef void UA_InvalidType;
  373. UA_TYPE_METHOD_PROTOTYPES (UA_InvalidType)
  374. #endif /* OPCUA_BASICTYPES_H_ */