PageRenderTime 115ms CodeModel.GetById 20ms RepoModel.GetById 1ms app.codeStats 0ms

/src/libyaml/yaml_private.h

https://code.google.com/
C Header | 635 lines | 372 code | 145 blank | 118 comment | 72 complexity | a12d0a899c8dd69536d4b0cb1e32ae65 MD5 | raw file
Possible License(s): GPL-2.0
  1. #if HAVE_CONFIG_H
  2. #include <config.h>
  3. #endif
  4. #include <yaml.h>
  5. #include <assert.h>
  6. #include <limits.h>
  7. /*
  8. * Memory management.
  9. */
  10. YAML_DECLARE(void *)
  11. yaml_malloc(size_t size);
  12. YAML_DECLARE(void *)
  13. yaml_realloc(void *ptr, size_t size);
  14. YAML_DECLARE(void)
  15. yaml_free(void *ptr);
  16. YAML_DECLARE(yaml_char_t *)
  17. yaml_strdup(const yaml_char_t *);
  18. /*
  19. * Reader: Ensure that the buffer contains at least `length` bytes.
  20. */
  21. YAML_DECLARE(int)
  22. yaml_parser_update_buffer(yaml_parser_t *parser, size_t length);
  23. /*
  24. * Scanner: Ensure that the token stack contains at least one token ready.
  25. */
  26. YAML_DECLARE(int)
  27. yaml_parser_fetch_more_tokens(yaml_parser_t *parser);
  28. /*
  29. * The size of the input raw buffer.
  30. */
  31. #define INPUT_RAW_BUFFER_SIZE 16384
  32. /*
  33. * The size of the input buffer.
  34. *
  35. * It should be possible to decode the whole raw buffer.
  36. */
  37. #define INPUT_BUFFER_SIZE (INPUT_RAW_BUFFER_SIZE*3)
  38. /*
  39. * The size of the output buffer.
  40. */
  41. #define OUTPUT_BUFFER_SIZE 16384
  42. /*
  43. * The size of the output raw buffer.
  44. *
  45. * It should be possible to encode the whole output buffer.
  46. */
  47. #define OUTPUT_RAW_BUFFER_SIZE (OUTPUT_BUFFER_SIZE*2+2)
  48. /*
  49. * The size of other stacks and queues.
  50. */
  51. #define INITIAL_STACK_SIZE 16
  52. #define INITIAL_QUEUE_SIZE 16
  53. #define INITIAL_STRING_SIZE 16
  54. /*
  55. * Buffer management.
  56. */
  57. #define BUFFER_INIT(context,buffer,size) \
  58. (((buffer).start = yaml_malloc(size)) ? \
  59. ((buffer).last = (buffer).pointer = (buffer).start, \
  60. (buffer).end = (buffer).start+(size), \
  61. 1) : \
  62. ((context)->error = YAML_MEMORY_ERROR, \
  63. 0))
  64. #define BUFFER_DEL(context,buffer) \
  65. (yaml_free((buffer).start), \
  66. (buffer).start = (buffer).pointer = (buffer).end = 0)
  67. /*
  68. * String management.
  69. */
  70. typedef struct {
  71. yaml_char_t *start;
  72. yaml_char_t *end;
  73. yaml_char_t *pointer;
  74. } yaml_string_t;
  75. YAML_DECLARE(int)
  76. yaml_string_extend(yaml_char_t **start,
  77. yaml_char_t **pointer, yaml_char_t **end);
  78. YAML_DECLARE(int)
  79. yaml_string_join(
  80. yaml_char_t **a_start, yaml_char_t **a_pointer, yaml_char_t **a_end,
  81. yaml_char_t **b_start, yaml_char_t **b_pointer, yaml_char_t **b_end);
  82. #define NULL_STRING { NULL, NULL, NULL }
  83. #define STRING(string,length) { (string), (string)+(length), (string) }
  84. #define STRING_ASSIGN(value,string,length) \
  85. ((value).start = (string), \
  86. (value).end = (string)+(length), \
  87. (value).pointer = (string))
  88. #define STRING_INIT(context,string,size) \
  89. (((string).start = yaml_malloc(size)) ? \
  90. ((string).pointer = (string).start, \
  91. (string).end = (string).start+(size), \
  92. memset((string).start, 0, (size)), \
  93. 1) : \
  94. ((context)->error = YAML_MEMORY_ERROR, \
  95. 0))
  96. #define STRING_DEL(context,string) \
  97. (yaml_free((string).start), \
  98. (string).start = (string).pointer = (string).end = 0)
  99. #define STRING_EXTEND(context,string) \
  100. (((string).pointer+5 < (string).end) \
  101. || yaml_string_extend(&(string).start, \
  102. &(string).pointer, &(string).end))
  103. #define CLEAR(context,string) \
  104. ((string).pointer = (string).start, \
  105. memset((string).start, 0, (string).end-(string).start))
  106. #define JOIN(context,string_a,string_b) \
  107. ((yaml_string_join(&(string_a).start, &(string_a).pointer, \
  108. &(string_a).end, &(string_b).start, \
  109. &(string_b).pointer, &(string_b).end)) ? \
  110. ((string_b).pointer = (string_b).start, \
  111. 1) : \
  112. ((context)->error = YAML_MEMORY_ERROR, \
  113. 0))
  114. /*
  115. * String check operations.
  116. */
  117. /*
  118. * Check the octet at the specified position.
  119. */
  120. #define CHECK_AT(string,octet,offset) \
  121. ((string).pointer[offset] == (yaml_char_t)(octet))
  122. /*
  123. * Check the current octet in the buffer.
  124. */
  125. #define CHECK(string,octet) CHECK_AT((string),(octet),0)
  126. /*
  127. * Check if the character at the specified position is an alphabetical
  128. * character, a digit, '_', or '-'.
  129. */
  130. #define IS_ALPHA_AT(string,offset) \
  131. (((string).pointer[offset] >= (yaml_char_t) '0' && \
  132. (string).pointer[offset] <= (yaml_char_t) '9') || \
  133. ((string).pointer[offset] >= (yaml_char_t) 'A' && \
  134. (string).pointer[offset] <= (yaml_char_t) 'Z') || \
  135. ((string).pointer[offset] >= (yaml_char_t) 'a' && \
  136. (string).pointer[offset] <= (yaml_char_t) 'z') || \
  137. (string).pointer[offset] == '_' || \
  138. (string).pointer[offset] == '-')
  139. #define IS_ALPHA(string) IS_ALPHA_AT((string),0)
  140. /*
  141. * Check if the character at the specified position is a digit.
  142. */
  143. #define IS_DIGIT_AT(string,offset) \
  144. (((string).pointer[offset] >= (yaml_char_t) '0' && \
  145. (string).pointer[offset] <= (yaml_char_t) '9'))
  146. #define IS_DIGIT(string) IS_DIGIT_AT((string),0)
  147. /*
  148. * Get the value of a digit.
  149. */
  150. #define AS_DIGIT_AT(string,offset) \
  151. ((string).pointer[offset] - (yaml_char_t) '0')
  152. #define AS_DIGIT(string) AS_DIGIT_AT((string),0)
  153. /*
  154. * Check if the character at the specified position is a hex-digit.
  155. */
  156. #define IS_HEX_AT(string,offset) \
  157. (((string).pointer[offset] >= (yaml_char_t) '0' && \
  158. (string).pointer[offset] <= (yaml_char_t) '9') || \
  159. ((string).pointer[offset] >= (yaml_char_t) 'A' && \
  160. (string).pointer[offset] <= (yaml_char_t) 'F') || \
  161. ((string).pointer[offset] >= (yaml_char_t) 'a' && \
  162. (string).pointer[offset] <= (yaml_char_t) 'f'))
  163. #define IS_HEX(string) IS_HEX_AT((string),0)
  164. /*
  165. * Get the value of a hex-digit.
  166. */
  167. #define AS_HEX_AT(string,offset) \
  168. (((string).pointer[offset] >= (yaml_char_t) 'A' && \
  169. (string).pointer[offset] <= (yaml_char_t) 'F') ? \
  170. ((string).pointer[offset] - (yaml_char_t) 'A' + 10) : \
  171. ((string).pointer[offset] >= (yaml_char_t) 'a' && \
  172. (string).pointer[offset] <= (yaml_char_t) 'f') ? \
  173. ((string).pointer[offset] - (yaml_char_t) 'a' + 10) : \
  174. ((string).pointer[offset] - (yaml_char_t) '0'))
  175. #define AS_HEX(string) AS_HEX_AT((string),0)
  176. /*
  177. * Check if the character is ASCII.
  178. */
  179. #define IS_ASCII_AT(string,offset) \
  180. ((string).pointer[offset] <= (yaml_char_t) '\x7F')
  181. #define IS_ASCII(string) IS_ASCII_AT((string),0)
  182. /*
  183. * Check if the character can be printed unescaped.
  184. * Only correct if you know you are looking at valid UTF-8!
  185. */
  186. #define IS_PRINTABLE_AT(string,offset) \
  187. (((string).pointer[offset] == 0x0A) /* . == #x0A */ \
  188. || ((string).pointer[offset] >= 0x20 /* #x20 <= . <= #x7E */ \
  189. && (string).pointer[offset] <= 0x7E) \
  190. || ((string).pointer[offset] == 0xC2 /* #0xA0 <= . <= #xD7FF */ \
  191. && (string).pointer[offset+1] >= 0xA0) \
  192. || ((string).pointer[offset] > 0xC2 \
  193. && (string).pointer[offset] < 0xED) \
  194. || ((string).pointer[offset] == 0xED \
  195. && (string).pointer[offset+1] < 0xA0) \
  196. || ((string).pointer[offset] == 0xEE) \
  197. || ((string).pointer[offset] == 0xEF /* #xE000 <= . <= #xFFFD */ \
  198. && !((string).pointer[offset+1] == 0xBB /* && . != #xFEFF */ \
  199. && (string).pointer[offset+2] == 0xBF) \
  200. && !((string).pointer[offset+1] == 0xBF \
  201. && ((string).pointer[offset+2] == 0xBE \
  202. || (string).pointer[offset+2] == 0xBF))))
  203. #define IS_PRINTABLE(string) IS_PRINTABLE_AT((string),0)
  204. /*
  205. * Check if the character at the specified position is NUL.
  206. */
  207. #define IS_Z_AT(string,offset) CHECK_AT((string),'\0',(offset))
  208. #define IS_Z(string) IS_Z_AT((string),0)
  209. /*
  210. * Check if the character at the specified position is BOM.
  211. */
  212. #define IS_BOM_AT(string,offset) \
  213. (CHECK_AT((string),'\xEF',(offset)) \
  214. && CHECK_AT((string),'\xBB',(offset)+1) \
  215. && CHECK_AT((string),'\xBF',(offset)+2)) /* BOM (#xFEFF) */
  216. #define IS_BOM(string) IS_BOM_AT(string,0)
  217. /*
  218. * Check if the character at the specified position is space.
  219. */
  220. #define IS_SPACE_AT(string,offset) CHECK_AT((string),' ',(offset))
  221. #define IS_SPACE(string) IS_SPACE_AT((string),0)
  222. /*
  223. * Check if the character at the specified position is tab.
  224. */
  225. #define IS_TAB_AT(string,offset) CHECK_AT((string),'\t',(offset))
  226. #define IS_TAB(string) IS_TAB_AT((string),0)
  227. /*
  228. * Check if the character at the specified position is blank (space or tab).
  229. */
  230. #define IS_BLANK_AT(string,offset) \
  231. (IS_SPACE_AT((string),(offset)) || IS_TAB_AT((string),(offset)))
  232. #define IS_BLANK(string) IS_BLANK_AT((string),0)
  233. /*
  234. * Check if the character at the specified position is a line break.
  235. */
  236. #define IS_BREAK_AT(string,offset) \
  237. (CHECK_AT((string),'\r',(offset)) /* CR (#xD)*/ \
  238. || CHECK_AT((string),'\n',(offset)) /* LF (#xA) */ \
  239. || (CHECK_AT((string),'\xC2',(offset)) \
  240. && CHECK_AT((string),'\x85',(offset)+1)) /* NEL (#x85) */ \
  241. || (CHECK_AT((string),'\xE2',(offset)) \
  242. && CHECK_AT((string),'\x80',(offset)+1) \
  243. && CHECK_AT((string),'\xA8',(offset)+2)) /* LS (#x2028) */ \
  244. || (CHECK_AT((string),'\xE2',(offset)) \
  245. && CHECK_AT((string),'\x80',(offset)+1) \
  246. && CHECK_AT((string),'\xA9',(offset)+2))) /* PS (#x2029) */
  247. #define IS_BREAK(string) IS_BREAK_AT((string),0)
  248. #define IS_CRLF_AT(string,offset) \
  249. (CHECK_AT((string),'\r',(offset)) && CHECK_AT((string),'\n',(offset)+1))
  250. #define IS_CRLF(string) IS_CRLF_AT((string),0)
  251. /*
  252. * Check if the character is a line break or NUL.
  253. */
  254. #define IS_BREAKZ_AT(string,offset) \
  255. (IS_BREAK_AT((string),(offset)) || IS_Z_AT((string),(offset)))
  256. #define IS_BREAKZ(string) IS_BREAKZ_AT((string),0)
  257. /*
  258. * Check if the character is a line break, space, or NUL.
  259. */
  260. #define IS_SPACEZ_AT(string,offset) \
  261. (IS_SPACE_AT((string),(offset)) || IS_BREAKZ_AT((string),(offset)))
  262. #define IS_SPACEZ(string) IS_SPACEZ_AT((string),0)
  263. /*
  264. * Check if the character is a line break, space, tab, or NUL.
  265. */
  266. #define IS_BLANKZ_AT(string,offset) \
  267. (IS_BLANK_AT((string),(offset)) || IS_BREAKZ_AT((string),(offset)))
  268. #define IS_BLANKZ(string) IS_BLANKZ_AT((string),0)
  269. /*
  270. * Determine the width of the character.
  271. * Only correct if you know you are looking at valid UTF-8!
  272. */
  273. #define WIDTH_AT(string,offset) \
  274. (((string).pointer[offset] & 0x80) == 0x00 ? 1 : \
  275. ((string).pointer[offset] & 0xE0) == 0xC0 ? 2 : \
  276. ((string).pointer[offset] & 0xF0) == 0xE0 ? 3 : \
  277. ((string).pointer[offset] & 0xF8) == 0xF0 ? 4 : 0)
  278. #define WIDTH(string) WIDTH_AT((string),0)
  279. /*
  280. * Move the string pointer to the next byte.
  281. */
  282. #define MOVE(string) ((string).pointer++)
  283. #define MOVEN(string,n) ((string).pointer += n)
  284. /*
  285. * Copy a byte and move the pointers of both strings.
  286. */
  287. #define COPY(string_a,string_b) \
  288. (*((string_a).pointer++) = *((string_b).pointer++))
  289. #define COPYN(string_a,string_b,n) \
  290. (memcpy(string_a.pointer, string_b.pointer, n), \
  291. string_a.pointer += n, string_b.pointer += n)
  292. /*
  293. * Stack and queue management.
  294. */
  295. YAML_DECLARE(int)
  296. yaml_stack_extend(void **start, void **top, void **end);
  297. YAML_DECLARE(int)
  298. yaml_queue_extend(void **start, void **head, void **tail, void **end);
  299. #define STACK_INIT(context,stack,size) \
  300. (((stack).start = yaml_malloc((size)*sizeof(*(stack).start))) ? \
  301. ((stack).top = (stack).start, \
  302. (stack).end = (stack).start+(size), \
  303. 1) : \
  304. ((context)->error = YAML_MEMORY_ERROR, \
  305. 0))
  306. #define STACK_DEL(context,stack) \
  307. (yaml_free((stack).start), \
  308. (stack).start = (stack).top = (stack).end = 0)
  309. #define STACK_EMPTY(context,stack) \
  310. ((stack).start == (stack).top)
  311. #define PUSH(context,stack,value) \
  312. (((stack).top != (stack).end \
  313. || yaml_stack_extend((void **)&(stack).start, \
  314. (void **)&(stack).top, (void **)&(stack).end)) ? \
  315. (*((stack).top++) = value, \
  316. 1) : \
  317. ((context)->error = YAML_MEMORY_ERROR, \
  318. 0))
  319. #define POP(context,stack) \
  320. (*(--(stack).top))
  321. #define QUEUE_INIT(context,queue,size) \
  322. (((queue).start = yaml_malloc((size)*sizeof(*(queue).start))) ? \
  323. ((queue).head = (queue).tail = (queue).start, \
  324. (queue).end = (queue).start+(size), \
  325. 1) : \
  326. ((context)->error = YAML_MEMORY_ERROR, \
  327. 0))
  328. #define QUEUE_DEL(context,queue) \
  329. (yaml_free((queue).start), \
  330. (queue).start = (queue).head = (queue).tail = (queue).end = 0)
  331. #define QUEUE_EMPTY(context,queue) \
  332. ((queue).head == (queue).tail)
  333. #define ENQUEUE(context,queue,value) \
  334. (((queue).tail != (queue).end \
  335. || yaml_queue_extend((void **)&(queue).start, (void **)&(queue).head, \
  336. (void **)&(queue).tail, (void **)&(queue).end)) ? \
  337. (*((queue).tail++) = value, \
  338. 1) : \
  339. ((context)->error = YAML_MEMORY_ERROR, \
  340. 0))
  341. #define DEQUEUE(context,queue) \
  342. (*((queue).head++))
  343. #define QUEUE_INSERT(context,queue,index,value) \
  344. (((queue).tail != (queue).end \
  345. || yaml_queue_extend((void **)&(queue).start, (void **)&(queue).head, \
  346. (void **)&(queue).tail, (void **)&(queue).end)) ? \
  347. (memmove((queue).head+(index)+1,(queue).head+(index), \
  348. ((queue).tail-(queue).head-(index))*sizeof(*(queue).start)), \
  349. *((queue).head+(index)) = value, \
  350. (queue).tail++, \
  351. 1) : \
  352. ((context)->error = YAML_MEMORY_ERROR, \
  353. 0))
  354. /*
  355. * Token initializers.
  356. */
  357. #define TOKEN_INIT(token,token_type,token_start_mark,token_end_mark) \
  358. (memset(&(token), 0, sizeof(yaml_token_t)), \
  359. (token).type = (token_type), \
  360. (token).start_mark = (token_start_mark), \
  361. (token).end_mark = (token_end_mark))
  362. #define STREAM_START_TOKEN_INIT(token,token_encoding,start_mark,end_mark) \
  363. (TOKEN_INIT((token),YAML_STREAM_START_TOKEN,(start_mark),(end_mark)), \
  364. (token).data.stream_start.encoding = (token_encoding))
  365. #define STREAM_END_TOKEN_INIT(token,start_mark,end_mark) \
  366. (TOKEN_INIT((token),YAML_STREAM_END_TOKEN,(start_mark),(end_mark)))
  367. #define ALIAS_TOKEN_INIT(token,token_value,start_mark,end_mark) \
  368. (TOKEN_INIT((token),YAML_ALIAS_TOKEN,(start_mark),(end_mark)), \
  369. (token).data.alias.value = (token_value))
  370. #define ANCHOR_TOKEN_INIT(token,token_value,start_mark,end_mark) \
  371. (TOKEN_INIT((token),YAML_ANCHOR_TOKEN,(start_mark),(end_mark)), \
  372. (token).data.anchor.value = (token_value))
  373. #define TAG_TOKEN_INIT(token,token_handle,token_suffix,start_mark,end_mark) \
  374. (TOKEN_INIT((token),YAML_TAG_TOKEN,(start_mark),(end_mark)), \
  375. (token).data.tag.handle = (token_handle), \
  376. (token).data.tag.suffix = (token_suffix))
  377. #define SCALAR_TOKEN_INIT(token,token_value,token_length,token_style,start_mark,end_mark) \
  378. (TOKEN_INIT((token),YAML_SCALAR_TOKEN,(start_mark),(end_mark)), \
  379. (token).data.scalar.value = (token_value), \
  380. (token).data.scalar.length = (token_length), \
  381. (token).data.scalar.style = (token_style))
  382. #define VERSION_DIRECTIVE_TOKEN_INIT(token,token_major,token_minor,start_mark,end_mark) \
  383. (TOKEN_INIT((token),YAML_VERSION_DIRECTIVE_TOKEN,(start_mark),(end_mark)), \
  384. (token).data.version_directive.major = (token_major), \
  385. (token).data.version_directive.minor = (token_minor))
  386. #define TAG_DIRECTIVE_TOKEN_INIT(token,token_handle,token_prefix,start_mark,end_mark) \
  387. (TOKEN_INIT((token),YAML_TAG_DIRECTIVE_TOKEN,(start_mark),(end_mark)), \
  388. (token).data.tag_directive.handle = (token_handle), \
  389. (token).data.tag_directive.prefix = (token_prefix))
  390. /*
  391. * Event initializers.
  392. */
  393. #define EVENT_INIT(event,event_type,event_start_mark,event_end_mark) \
  394. (memset(&(event), 0, sizeof(yaml_event_t)), \
  395. (event).type = (event_type), \
  396. (event).start_mark = (event_start_mark), \
  397. (event).end_mark = (event_end_mark))
  398. #define STREAM_START_EVENT_INIT(event,event_encoding,start_mark,end_mark) \
  399. (EVENT_INIT((event),YAML_STREAM_START_EVENT,(start_mark),(end_mark)), \
  400. (event).data.stream_start.encoding = (event_encoding))
  401. #define STREAM_END_EVENT_INIT(event,start_mark,end_mark) \
  402. (EVENT_INIT((event),YAML_STREAM_END_EVENT,(start_mark),(end_mark)))
  403. #define DOCUMENT_START_EVENT_INIT(event,event_version_directive, \
  404. event_tag_directives_start,event_tag_directives_end,event_implicit,start_mark,end_mark) \
  405. (EVENT_INIT((event),YAML_DOCUMENT_START_EVENT,(start_mark),(end_mark)), \
  406. (event).data.document_start.version_directive = (event_version_directive), \
  407. (event).data.document_start.tag_directives.start = (event_tag_directives_start), \
  408. (event).data.document_start.tag_directives.end = (event_tag_directives_end), \
  409. (event).data.document_start.implicit = (event_implicit))
  410. #define DOCUMENT_END_EVENT_INIT(event,event_implicit,start_mark,end_mark) \
  411. (EVENT_INIT((event),YAML_DOCUMENT_END_EVENT,(start_mark),(end_mark)), \
  412. (event).data.document_end.implicit = (event_implicit))
  413. #define ALIAS_EVENT_INIT(event,event_anchor,start_mark,end_mark) \
  414. (EVENT_INIT((event),YAML_ALIAS_EVENT,(start_mark),(end_mark)), \
  415. (event).data.alias.anchor = (event_anchor))
  416. #define SCALAR_EVENT_INIT(event,event_anchor,event_tag,event_value,event_length, \
  417. event_plain_implicit, event_quoted_implicit,event_style,start_mark,end_mark) \
  418. (EVENT_INIT((event),YAML_SCALAR_EVENT,(start_mark),(end_mark)), \
  419. (event).data.scalar.anchor = (event_anchor), \
  420. (event).data.scalar.tag = (event_tag), \
  421. (event).data.scalar.value = (event_value), \
  422. (event).data.scalar.length = (event_length), \
  423. (event).data.scalar.plain_implicit = (event_plain_implicit), \
  424. (event).data.scalar.quoted_implicit = (event_quoted_implicit), \
  425. (event).data.scalar.style = (event_style))
  426. #define SEQUENCE_START_EVENT_INIT(event,event_anchor,event_tag, \
  427. event_implicit,event_style,start_mark,end_mark) \
  428. (EVENT_INIT((event),YAML_SEQUENCE_START_EVENT,(start_mark),(end_mark)), \
  429. (event).data.sequence_start.anchor = (event_anchor), \
  430. (event).data.sequence_start.tag = (event_tag), \
  431. (event).data.sequence_start.implicit = (event_implicit), \
  432. (event).data.sequence_start.style = (event_style))
  433. #define SEQUENCE_END_EVENT_INIT(event,start_mark,end_mark) \
  434. (EVENT_INIT((event),YAML_SEQUENCE_END_EVENT,(start_mark),(end_mark)))
  435. #define MAPPING_START_EVENT_INIT(event,event_anchor,event_tag, \
  436. event_implicit,event_style,start_mark,end_mark) \
  437. (EVENT_INIT((event),YAML_MAPPING_START_EVENT,(start_mark),(end_mark)), \
  438. (event).data.mapping_start.anchor = (event_anchor), \
  439. (event).data.mapping_start.tag = (event_tag), \
  440. (event).data.mapping_start.implicit = (event_implicit), \
  441. (event).data.mapping_start.style = (event_style))
  442. #define MAPPING_END_EVENT_INIT(event,start_mark,end_mark) \
  443. (EVENT_INIT((event),YAML_MAPPING_END_EVENT,(start_mark),(end_mark)))
  444. /*
  445. * Document initializer.
  446. */
  447. #define DOCUMENT_INIT(document,document_nodes_start,document_nodes_end, \
  448. document_version_directive,document_tag_directives_start, \
  449. document_tag_directives_end,document_start_implicit, \
  450. document_end_implicit,document_start_mark,document_end_mark) \
  451. (memset(&(document), 0, sizeof(yaml_document_t)), \
  452. (document).nodes.start = (document_nodes_start), \
  453. (document).nodes.end = (document_nodes_end), \
  454. (document).nodes.top = (document_nodes_start), \
  455. (document).version_directive = (document_version_directive), \
  456. (document).tag_directives.start = (document_tag_directives_start), \
  457. (document).tag_directives.end = (document_tag_directives_end), \
  458. (document).start_implicit = (document_start_implicit), \
  459. (document).end_implicit = (document_end_implicit), \
  460. (document).start_mark = (document_start_mark), \
  461. (document).end_mark = (document_end_mark))
  462. /*
  463. * Node initializers.
  464. */
  465. #define NODE_INIT(node,node_type,node_tag,node_start_mark,node_end_mark) \
  466. (memset(&(node), 0, sizeof(yaml_node_t)), \
  467. (node).type = (node_type), \
  468. (node).tag = (node_tag), \
  469. (node).start_mark = (node_start_mark), \
  470. (node).end_mark = (node_end_mark))
  471. #define SCALAR_NODE_INIT(node,node_tag,node_value,node_length, \
  472. node_style,start_mark,end_mark) \
  473. (NODE_INIT((node),YAML_SCALAR_NODE,(node_tag),(start_mark),(end_mark)), \
  474. (node).data.scalar.value = (node_value), \
  475. (node).data.scalar.length = (node_length), \
  476. (node).data.scalar.style = (node_style))
  477. #define SEQUENCE_NODE_INIT(node,node_tag,node_items_start,node_items_end, \
  478. node_style,start_mark,end_mark) \
  479. (NODE_INIT((node),YAML_SEQUENCE_NODE,(node_tag),(start_mark),(end_mark)), \
  480. (node).data.sequence.items.start = (node_items_start), \
  481. (node).data.sequence.items.end = (node_items_end), \
  482. (node).data.sequence.items.top = (node_items_start), \
  483. (node).data.sequence.style = (node_style))
  484. #define MAPPING_NODE_INIT(node,node_tag,node_pairs_start,node_pairs_end, \
  485. node_style,start_mark,end_mark) \
  486. (NODE_INIT((node),YAML_MAPPING_NODE,(node_tag),(start_mark),(end_mark)), \
  487. (node).data.mapping.pairs.start = (node_pairs_start), \
  488. (node).data.mapping.pairs.end = (node_pairs_end), \
  489. (node).data.mapping.pairs.top = (node_pairs_start), \
  490. (node).data.mapping.style = (node_style))