yaml_privateh.go 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892
  1. /*
  2. Licensed under the Apache License, Version 2.0 (the "License");
  3. you may not use this file except in compliance with the License.
  4. You may obtain a copy of the License at
  5. http://www.apache.org/licenses/LICENSE-2.0
  6. Unless required by applicable law or agreed to in writing, software
  7. distributed under the License is distributed on an "AS IS" BASIS,
  8. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  9. See the License for the specific language governing permissions and
  10. limitations under the License.
  11. */
  12. package candiedyaml
  13. const (
  14. INPUT_RAW_BUFFER_SIZE = 1024
  15. /*
  16. * The size of the input buffer.
  17. *
  18. * It should be possible to decode the whole raw buffer.
  19. */
  20. INPUT_BUFFER_SIZE = (INPUT_RAW_BUFFER_SIZE * 3)
  21. /*
  22. * The size of the output buffer.
  23. */
  24. OUTPUT_BUFFER_SIZE = 512
  25. /*
  26. * The size of the output raw buffer.
  27. *
  28. * It should be possible to encode the whole output buffer.
  29. */
  30. OUTPUT_RAW_BUFFER_SIZE = (OUTPUT_BUFFER_SIZE*2 + 2)
  31. INITIAL_STACK_SIZE = 16
  32. INITIAL_QUEUE_SIZE = 16
  33. )
  34. func width(b byte) int {
  35. if b&0x80 == 0 {
  36. return 1
  37. }
  38. if b&0xE0 == 0xC0 {
  39. return 2
  40. }
  41. if b&0xF0 == 0xE0 {
  42. return 3
  43. }
  44. if b&0xF8 == 0xF0 {
  45. return 4
  46. }
  47. return 0
  48. }
  49. func copy_bytes(dest []byte, dest_pos *int, src []byte, src_pos *int) {
  50. w := width(src[*src_pos])
  51. switch w {
  52. case 4:
  53. dest[*dest_pos+3] = src[*src_pos+3]
  54. fallthrough
  55. case 3:
  56. dest[*dest_pos+2] = src[*src_pos+2]
  57. fallthrough
  58. case 2:
  59. dest[*dest_pos+1] = src[*src_pos+1]
  60. fallthrough
  61. case 1:
  62. dest[*dest_pos] = src[*src_pos]
  63. default:
  64. panic("invalid width")
  65. }
  66. *dest_pos += w
  67. *src_pos += w
  68. }
  69. // /*
  70. // * Check if the character at the specified position is an alphabetical
  71. // * character, a digit, '_', or '-'.
  72. // */
  73. func is_alpha(b byte) bool {
  74. return (b >= '0' && b <= '9') ||
  75. (b >= 'A' && b <= 'Z') ||
  76. (b >= 'a' && b <= 'z') ||
  77. b == '_' || b == '-'
  78. }
  79. // /*
  80. // * Check if the character at the specified position is a digit.
  81. // */
  82. //
  83. func is_digit(b byte) bool {
  84. return b >= '0' && b <= '9'
  85. }
  86. // /*
  87. // * Get the value of a digit.
  88. // */
  89. //
  90. func as_digit(b byte) int {
  91. return int(b) - '0'
  92. }
  93. // /*
  94. // * Check if the character at the specified position is a hex-digit.
  95. // */
  96. //
  97. func is_hex(b byte) bool {
  98. return (b >= '0' && b <= '9') ||
  99. (b >= 'A' && b <= 'F') ||
  100. (b >= 'a' && b <= 'f')
  101. }
  102. //
  103. // /*
  104. // * Get the value of a hex-digit.
  105. // */
  106. //
  107. func as_hex(b byte) int {
  108. if b >= 'A' && b <= 'F' {
  109. return int(b) - 'A' + 10
  110. } else if b >= 'a' && b <= 'f' {
  111. return int(b) - 'a' + 10
  112. }
  113. return int(b) - '0'
  114. }
  115. // #define AS_HEX_AT(string,offset) \
  116. // (((string).pointer[offset] >= (yaml_char_t) 'A' && \
  117. // (string).pointer[offset] <= (yaml_char_t) 'F') ? \
  118. // ((string).pointer[offset] - (yaml_char_t) 'A' + 10) : \
  119. // ((string).pointer[offset] >= (yaml_char_t) 'a' && \
  120. // (string).pointer[offset] <= (yaml_char_t) 'f') ? \
  121. // ((string).pointer[offset] - (yaml_char_t) 'a' + 10) : \
  122. // ((string).pointer[offset] - (yaml_char_t) '0'))
  123. // /*
  124. // * Check if the character is a line break, space, tab, or NUL.
  125. // */
  126. func is_blankz_at(b []byte, i int) bool {
  127. return is_blank(b[i]) || is_breakz_at(b, i)
  128. }
  129. // /*
  130. // * Check if the character at the specified position is a line break.
  131. // */
  132. func is_break_at(b []byte, i int) bool {
  133. return b[i] == '\r' || /* CR (#xD)*/
  134. b[i] == '\n' || /* LF (#xA) */
  135. (b[i] == 0xC2 && b[i+1] == 0x85) || /* NEL (#x85) */
  136. (b[i] == 0xE2 && b[i+1] == 0x80 && b[i+2] == 0xA8) || /* LS (#x2028) */
  137. (b[i] == 0xE2 && b[i+1] == 0x80 && b[i+2] == 0xA9) /* PS (#x2029) */
  138. }
  139. func is_breakz_at(b []byte, i int) bool {
  140. return is_break_at(b, i) || is_z(b[i])
  141. }
  142. func is_crlf_at(b []byte, i int) bool {
  143. return b[i] == '\r' && b[i+1] == '\n'
  144. }
  145. // /*
  146. // * Check if the character at the specified position is NUL.
  147. // */
  148. func is_z(b byte) bool {
  149. return b == 0x0
  150. }
  151. // /*
  152. // * Check if the character at the specified position is space.
  153. // */
  154. func is_space(b byte) bool {
  155. return b == ' '
  156. }
  157. //
  158. // /*
  159. // * Check if the character at the specified position is tab.
  160. // */
  161. func is_tab(b byte) bool {
  162. return b == '\t'
  163. }
  164. // /*
  165. // * Check if the character at the specified position is blank (space or tab).
  166. // */
  167. func is_blank(b byte) bool {
  168. return is_space(b) || is_tab(b)
  169. }
  170. // /*
  171. // * Check if the character is ASCII.
  172. // */
  173. func is_ascii(b byte) bool {
  174. return b <= '\x7f'
  175. }
  176. // /*
  177. // * Check if the character can be printed unescaped.
  178. // */
  179. func is_printable_at(b []byte, i int) bool {
  180. return ((b[i] == 0x0A) || /* . == #x0A */
  181. (b[i] >= 0x20 && b[i] <= 0x7E) || /* #x20 <= . <= #x7E */
  182. (b[i] == 0xC2 && b[i+1] >= 0xA0) || /* #0xA0 <= . <= #xD7FF */
  183. (b[i] > 0xC2 && b[i] < 0xED) ||
  184. (b[i] == 0xED && b[i+1] < 0xA0) ||
  185. (b[i] == 0xEE) ||
  186. (b[i] == 0xEF && /* && . != #xFEFF */
  187. !(b[i+1] == 0xBB && b[i+2] == 0xBF) &&
  188. !(b[i+1] == 0xBF && (b[i+2] == 0xBE || b[i+2] == 0xBF))))
  189. }
  190. func insert_token(parser *yaml_parser_t, pos int, token *yaml_token_t) {
  191. // collapse the slice
  192. if parser.tokens_head > 0 && len(parser.tokens) == cap(parser.tokens) {
  193. if parser.tokens_head != len(parser.tokens) {
  194. // move the tokens down
  195. copy(parser.tokens, parser.tokens[parser.tokens_head:])
  196. }
  197. // readjust the length
  198. parser.tokens = parser.tokens[:len(parser.tokens)-parser.tokens_head]
  199. parser.tokens_head = 0
  200. }
  201. parser.tokens = append(parser.tokens, *token)
  202. if pos < 0 {
  203. return
  204. }
  205. copy(parser.tokens[parser.tokens_head+pos+1:], parser.tokens[parser.tokens_head+pos:])
  206. parser.tokens[parser.tokens_head+pos] = *token
  207. }
  208. // /*
  209. // * Check if the character at the specified position is BOM.
  210. // */
  211. //
  212. func is_bom_at(b []byte, i int) bool {
  213. return b[i] == 0xEF && b[i+1] == 0xBB && b[i+2] == 0xBF
  214. }
  215. //
  216. // #ifdef HAVE_CONFIG_H
  217. // #include <config.h>
  218. // #endif
  219. //
  220. // #include "./yaml.h"
  221. //
  222. // #include <assert.h>
  223. // #include <limits.h>
  224. //
  225. // /*
  226. // * Memory management.
  227. // */
  228. //
  229. // yaml_DECLARE(void *)
  230. // yaml_malloc(size_t size);
  231. //
  232. // yaml_DECLARE(void *)
  233. // yaml_realloc(void *ptr, size_t size);
  234. //
  235. // yaml_DECLARE(void)
  236. // yaml_free(void *ptr);
  237. //
  238. // yaml_DECLARE(yaml_char_t *)
  239. // yaml_strdup(const yaml_char_t *);
  240. //
  241. // /*
  242. // * Reader: Ensure that the buffer contains at least `length` characters.
  243. // */
  244. //
  245. // yaml_DECLARE(int)
  246. // yaml_parser_update_buffer(yaml_parser_t *parser, size_t length);
  247. //
  248. // /*
  249. // * Scanner: Ensure that the token stack contains at least one token ready.
  250. // */
  251. //
  252. // yaml_DECLARE(int)
  253. // yaml_parser_fetch_more_tokens(yaml_parser_t *parser);
  254. //
  255. // /*
  256. // * The size of the input raw buffer.
  257. // */
  258. //
  259. // #define INPUT_RAW_BUFFER_SIZE 16384
  260. //
  261. // /*
  262. // * The size of the input buffer.
  263. // *
  264. // * It should be possible to decode the whole raw buffer.
  265. // */
  266. //
  267. // #define INPUT_BUFFER_SIZE (INPUT_RAW_BUFFER_SIZE*3)
  268. //
  269. // /*
  270. // * The size of the output buffer.
  271. // */
  272. //
  273. // #define OUTPUT_BUFFER_SIZE 16384
  274. //
  275. // /*
  276. // * The size of the output raw buffer.
  277. // *
  278. // * It should be possible to encode the whole output buffer.
  279. // */
  280. //
  281. // #define OUTPUT_RAW_BUFFER_SIZE (OUTPUT_BUFFER_SIZE*2+2)
  282. //
  283. // /*
  284. // * The size of other stacks and queues.
  285. // */
  286. //
  287. // #define INITIAL_STACK_SIZE 16
  288. // #define INITIAL_QUEUE_SIZE 16
  289. // #define INITIAL_STRING_SIZE 16
  290. //
  291. // /*
  292. // * Buffer management.
  293. // */
  294. //
  295. // #define BUFFER_INIT(context,buffer,size) \
  296. // (((buffer).start = yaml_malloc(size)) ? \
  297. // ((buffer).last = (buffer).pointer = (buffer).start, \
  298. // (buffer).end = (buffer).start+(size), \
  299. // 1) : \
  300. // ((context)->error = yaml_MEMORY_ERROR, \
  301. // 0))
  302. //
  303. // #define BUFFER_DEL(context,buffer) \
  304. // (yaml_free((buffer).start), \
  305. // (buffer).start = (buffer).pointer = (buffer).end = 0)
  306. //
  307. // /*
  308. // * String management.
  309. // */
  310. //
  311. // typedef struct {
  312. // yaml_char_t *start;
  313. // yaml_char_t *end;
  314. // yaml_char_t *pointer;
  315. // } yaml_string_t;
  316. //
  317. // yaml_DECLARE(int)
  318. // yaml_string_extend(yaml_char_t **start,
  319. // yaml_char_t **pointer, yaml_char_t **end);
  320. //
  321. // yaml_DECLARE(int)
  322. // yaml_string_join(
  323. // yaml_char_t **a_start, yaml_char_t **a_pointer, yaml_char_t **a_end,
  324. // yaml_char_t **b_start, yaml_char_t **b_pointer, yaml_char_t **b_end);
  325. //
  326. // #define NULL_STRING { NULL, NULL, NULL }
  327. //
  328. // #define STRING(string,length) { (string), (string)+(length), (string) }
  329. //
  330. // #define STRING_ASSIGN(value,string,length) \
  331. // ((value).start = (string), \
  332. // (value).end = (string)+(length), \
  333. // (value).pointer = (string))
  334. //
  335. // #define STRING_INIT(context,string,size) \
  336. // (((string).start = yaml_malloc(size)) ? \
  337. // ((string).pointer = (string).start, \
  338. // (string).end = (string).start+(size), \
  339. // memset((string).start, 0, (size)), \
  340. // 1) : \
  341. // ((context)->error = yaml_MEMORY_ERROR, \
  342. // 0))
  343. //
  344. // #define STRING_DEL(context,string) \
  345. // (yaml_free((string).start), \
  346. // (string).start = (string).pointer = (string).end = 0)
  347. //
  348. // #define STRING_EXTEND(context,string) \
  349. // (((string).pointer+5 < (string).end) \
  350. // || yaml_string_extend(&(string).start, \
  351. // &(string).pointer, &(string).end))
  352. //
  353. // #define CLEAR(context,string) \
  354. // ((string).pointer = (string).start, \
  355. // memset((string).start, 0, (string).end-(string).start))
  356. //
  357. // #define JOIN(context,string_a,string_b) \
  358. // ((yaml_string_join(&(string_a).start, &(string_a).pointer, \
  359. // &(string_a).end, &(string_b).start, \
  360. // &(string_b).pointer, &(string_b).end)) ? \
  361. // ((string_b).pointer = (string_b).start, \
  362. // 1) : \
  363. // ((context)->error = yaml_MEMORY_ERROR, \
  364. // 0))
  365. //
  366. // /*
  367. // * String check operations.
  368. // */
  369. //
  370. // /*
  371. // * Check the octet at the specified position.
  372. // */
  373. //
  374. // #define CHECK_AT(string,octet,offset) \
  375. // ((string).pointer[offset] == (yaml_char_t)(octet))
  376. //
  377. // /*
  378. // * Check the current octet in the buffer.
  379. // */
  380. //
  381. // #define CHECK(string,octet) CHECK_AT((string),(octet),0)
  382. //
  383. // /*
  384. // * Check if the character at the specified position is an alphabetical
  385. // * character, a digit, '_', or '-'.
  386. // */
  387. //
  388. // #define IS_ALPHA_AT(string,offset) \
  389. // (((string).pointer[offset] >= (yaml_char_t) '0' && \
  390. // (string).pointer[offset] <= (yaml_char_t) '9') || \
  391. // ((string).pointer[offset] >= (yaml_char_t) 'A' && \
  392. // (string).pointer[offset] <= (yaml_char_t) 'Z') || \
  393. // ((string).pointer[offset] >= (yaml_char_t) 'a' && \
  394. // (string).pointer[offset] <= (yaml_char_t) 'z') || \
  395. // (string).pointer[offset] == '_' || \
  396. // (string).pointer[offset] == '-')
  397. //
  398. // #define IS_ALPHA(string) IS_ALPHA_AT((string),0)
  399. //
  400. // /*
  401. // * Check if the character at the specified position is a digit.
  402. // */
  403. //
  404. // #define IS_DIGIT_AT(string,offset) \
  405. // (((string).pointer[offset] >= (yaml_char_t) '0' && \
  406. // (string).pointer[offset] <= (yaml_char_t) '9'))
  407. //
  408. // #define IS_DIGIT(string) IS_DIGIT_AT((string),0)
  409. //
  410. // /*
  411. // * Get the value of a digit.
  412. // */
  413. //
  414. // #define AS_DIGIT_AT(string,offset) \
  415. // ((string).pointer[offset] - (yaml_char_t) '0')
  416. //
  417. // #define AS_DIGIT(string) AS_DIGIT_AT((string),0)
  418. //
  419. // /*
  420. // * Check if the character at the specified position is a hex-digit.
  421. // */
  422. //
  423. // #define IS_HEX_AT(string,offset) \
  424. // (((string).pointer[offset] >= (yaml_char_t) '0' && \
  425. // (string).pointer[offset] <= (yaml_char_t) '9') || \
  426. // ((string).pointer[offset] >= (yaml_char_t) 'A' && \
  427. // (string).pointer[offset] <= (yaml_char_t) 'F') || \
  428. // ((string).pointer[offset] >= (yaml_char_t) 'a' && \
  429. // (string).pointer[offset] <= (yaml_char_t) 'f'))
  430. //
  431. // #define IS_HEX(string) IS_HEX_AT((string),0)
  432. //
  433. // /*
  434. // * Get the value of a hex-digit.
  435. // */
  436. //
  437. // #define AS_HEX_AT(string,offset) \
  438. // (((string).pointer[offset] >= (yaml_char_t) 'A' && \
  439. // (string).pointer[offset] <= (yaml_char_t) 'F') ? \
  440. // ((string).pointer[offset] - (yaml_char_t) 'A' + 10) : \
  441. // ((string).pointer[offset] >= (yaml_char_t) 'a' && \
  442. // (string).pointer[offset] <= (yaml_char_t) 'f') ? \
  443. // ((string).pointer[offset] - (yaml_char_t) 'a' + 10) : \
  444. // ((string).pointer[offset] - (yaml_char_t) '0'))
  445. //
  446. // #define AS_HEX(string) AS_HEX_AT((string),0)
  447. //
  448. // /*
  449. // * Check if the character is ASCII.
  450. // */
  451. //
  452. // #define IS_ASCII_AT(string,offset) \
  453. // ((string).pointer[offset] <= (yaml_char_t) '\x7F')
  454. //
  455. // #define IS_ASCII(string) IS_ASCII_AT((string),0)
  456. //
  457. // /*
  458. // * Check if the character can be printed unescaped.
  459. // */
  460. //
  461. // #define IS_PRINTABLE_AT(string,offset) \
  462. // (((string).pointer[offset] == 0x0A) /* . == #x0A */ \
  463. // || ((string).pointer[offset] >= 0x20 /* #x20 <= . <= #x7E */ \
  464. // && (string).pointer[offset] <= 0x7E) \
  465. // || ((string).pointer[offset] == 0xC2 /* #0xA0 <= . <= #xD7FF */ \
  466. // && (string).pointer[offset+1] >= 0xA0) \
  467. // || ((string).pointer[offset] > 0xC2 \
  468. // && (string).pointer[offset] < 0xED) \
  469. // || ((string).pointer[offset] == 0xED \
  470. // && (string).pointer[offset+1] < 0xA0) \
  471. // || ((string).pointer[offset] == 0xEE) \
  472. // || ((string).pointer[offset] == 0xEF /* #xE000 <= . <= #xFFFD */ \
  473. // && !((string).pointer[offset+1] == 0xBB /* && . != #xFEFF */ \
  474. // && (string).pointer[offset+2] == 0xBF) \
  475. // && !((string).pointer[offset+1] == 0xBF \
  476. // && ((string).pointer[offset+2] == 0xBE \
  477. // || (string).pointer[offset+2] == 0xBF))))
  478. //
  479. // #define IS_PRINTABLE(string) IS_PRINTABLE_AT((string),0)
  480. //
  481. // /*
  482. // * Check if the character at the specified position is NUL.
  483. // */
  484. //
  485. // #define IS_Z_AT(string,offset) CHECK_AT((string),'\0',(offset))
  486. //
  487. // #define IS_Z(string) IS_Z_AT((string),0)
  488. //
  489. // /*
  490. // * Check if the character at the specified position is BOM.
  491. // */
  492. //
  493. // #define IS_BOM_AT(string,offset) \
  494. // (CHECK_AT((string),'\xEF',(offset)) \
  495. // && CHECK_AT((string),'\xBB',(offset)+1) \
  496. // && CHECK_AT((string),'\xBF',(offset)+2)) /* BOM (#xFEFF) */
  497. //
  498. // #define IS_BOM(string) IS_BOM_AT(string,0)
  499. //
  500. // /*
  501. // * Check if the character at the specified position is space.
  502. // */
  503. //
  504. // #define IS_SPACE_AT(string,offset) CHECK_AT((string),' ',(offset))
  505. //
  506. // #define IS_SPACE(string) IS_SPACE_AT((string),0)
  507. //
  508. // /*
  509. // * Check if the character at the specified position is tab.
  510. // */
  511. //
  512. // #define IS_TAB_AT(string,offset) CHECK_AT((string),'\t',(offset))
  513. //
  514. // #define IS_TAB(string) IS_TAB_AT((string),0)
  515. //
  516. // /*
  517. // * Check if the character at the specified position is blank (space or tab).
  518. // */
  519. //
  520. // #define IS_BLANK_AT(string,offset) \
  521. // (IS_SPACE_AT((string),(offset)) || IS_TAB_AT((string),(offset)))
  522. //
  523. // #define IS_BLANK(string) IS_BLANK_AT((string),0)
  524. //
  525. // /*
  526. // * Check if the character at the specified position is a line break.
  527. // */
  528. //
  529. // #define IS_BREAK_AT(string,offset) \
  530. // (CHECK_AT((string),'\r',(offset)) /* CR (#xD)*/ \
  531. // || CHECK_AT((string),'\n',(offset)) /* LF (#xA) */ \
  532. // || (CHECK_AT((string),'\xC2',(offset)) \
  533. // && CHECK_AT((string),'\x85',(offset)+1)) /* NEL (#x85) */ \
  534. // || (CHECK_AT((string),'\xE2',(offset)) \
  535. // && CHECK_AT((string),'\x80',(offset)+1) \
  536. // && CHECK_AT((string),'\xA8',(offset)+2)) /* LS (#x2028) */ \
  537. // || (CHECK_AT((string),'\xE2',(offset)) \
  538. // && CHECK_AT((string),'\x80',(offset)+1) \
  539. // && CHECK_AT((string),'\xA9',(offset)+2))) /* PS (#x2029) */
  540. //
  541. // #define IS_BREAK(string) IS_BREAK_AT((string),0)
  542. //
  543. // #define IS_CRLF_AT(string,offset) \
  544. // (CHECK_AT((string),'\r',(offset)) && CHECK_AT((string),'\n',(offset)+1))
  545. //
  546. // #define IS_CRLF(string) IS_CRLF_AT((string),0)
  547. //
  548. // /*
  549. // * Check if the character is a line break or NUL.
  550. // */
  551. //
  552. // #define IS_BREAKZ_AT(string,offset) \
  553. // (IS_BREAK_AT((string),(offset)) || IS_Z_AT((string),(offset)))
  554. //
  555. // #define IS_BREAKZ(string) IS_BREAKZ_AT((string),0)
  556. //
  557. // /*
  558. // * Check if the character is a line break, space, or NUL.
  559. // */
  560. //
  561. // #define IS_SPACEZ_AT(string,offset) \
  562. // (IS_SPACE_AT((string),(offset)) || IS_BREAKZ_AT((string),(offset)))
  563. //
  564. // #define IS_SPACEZ(string) IS_SPACEZ_AT((string),0)
  565. //
  566. // /*
  567. // * Check if the character is a line break, space, tab, or NUL.
  568. // */
  569. //
  570. // #define IS_BLANKZ_AT(string,offset) \
  571. // (IS_BLANK_AT((string),(offset)) || IS_BREAKZ_AT((string),(offset)))
  572. //
  573. // #define IS_BLANKZ(string) IS_BLANKZ_AT((string),0)
  574. //
  575. // /*
  576. // * Determine the width of the character.
  577. // */
  578. //
  579. // #define WIDTH_AT(string,offset) \
  580. // (((string).pointer[offset] & 0x80) == 0x00 ? 1 : \
  581. // ((string).pointer[offset] & 0xE0) == 0xC0 ? 2 : \
  582. // ((string).pointer[offset] & 0xF0) == 0xE0 ? 3 : \
  583. // ((string).pointer[offset] & 0xF8) == 0xF0 ? 4 : 0)
  584. //
  585. // #define WIDTH(string) WIDTH_AT((string),0)
  586. //
  587. // /*
  588. // * Move the string pointer to the next character.
  589. // */
  590. //
  591. // #define MOVE(string) ((string).pointer += WIDTH((string)))
  592. //
  593. // /*
  594. // * Copy a character and move the pointers of both strings.
  595. // */
  596. //
  597. // #define COPY(string_a,string_b) \
  598. // ((*(string_b).pointer & 0x80) == 0x00 ? \
  599. // (*((string_a).pointer++) = *((string_b).pointer++)) : \
  600. // (*(string_b).pointer & 0xE0) == 0xC0 ? \
  601. // (*((string_a).pointer++) = *((string_b).pointer++), \
  602. // *((string_a).pointer++) = *((string_b).pointer++)) : \
  603. // (*(string_b).pointer & 0xF0) == 0xE0 ? \
  604. // (*((string_a).pointer++) = *((string_b).pointer++), \
  605. // *((string_a).pointer++) = *((string_b).pointer++), \
  606. // *((string_a).pointer++) = *((string_b).pointer++)) : \
  607. // (*(string_b).pointer & 0xF8) == 0xF0 ? \
  608. // (*((string_a).pointer++) = *((string_b).pointer++), \
  609. // *((string_a).pointer++) = *((string_b).pointer++), \
  610. // *((string_a).pointer++) = *((string_b).pointer++), \
  611. // *((string_a).pointer++) = *((string_b).pointer++)) : 0)
  612. //
  613. // /*
  614. // * Stack and queue management.
  615. // */
  616. //
  617. // yaml_DECLARE(int)
  618. // yaml_stack_extend(void **start, void **top, void **end);
  619. //
  620. // yaml_DECLARE(int)
  621. // yaml_queue_extend(void **start, void **head, void **tail, void **end);
  622. //
  623. // #define STACK_INIT(context,stack,size) \
  624. // (((stack).start = yaml_malloc((size)*sizeof(*(stack).start))) ? \
  625. // ((stack).top = (stack).start, \
  626. // (stack).end = (stack).start+(size), \
  627. // 1) : \
  628. // ((context)->error = yaml_MEMORY_ERROR, \
  629. // 0))
  630. //
  631. // #define STACK_DEL(context,stack) \
  632. // (yaml_free((stack).start), \
  633. // (stack).start = (stack).top = (stack).end = 0)
  634. //
  635. // #define STACK_EMPTY(context,stack) \
  636. // ((stack).start == (stack).top)
  637. //
  638. // #define PUSH(context,stack,value) \
  639. // (((stack).top != (stack).end \
  640. // || yaml_stack_extend((void **)&(stack).start, \
  641. // (void **)&(stack).top, (void **)&(stack).end)) ? \
  642. // (*((stack).top++) = value, \
  643. // 1) : \
  644. // ((context)->error = yaml_MEMORY_ERROR, \
  645. // 0))
  646. //
  647. // #define POP(context,stack) \
  648. // (*(--(stack).top))
  649. //
  650. // #define QUEUE_INIT(context,queue,size) \
  651. // (((queue).start = yaml_malloc((size)*sizeof(*(queue).start))) ? \
  652. // ((queue).head = (queue).tail = (queue).start, \
  653. // (queue).end = (queue).start+(size), \
  654. // 1) : \
  655. // ((context)->error = yaml_MEMORY_ERROR, \
  656. // 0))
  657. //
  658. // #define QUEUE_DEL(context,queue) \
  659. // (yaml_free((queue).start), \
  660. // (queue).start = (queue).head = (queue).tail = (queue).end = 0)
  661. //
  662. // #define QUEUE_EMPTY(context,queue) \
  663. // ((queue).head == (queue).tail)
  664. //
  665. // #define ENQUEUE(context,queue,value) \
  666. // (((queue).tail != (queue).end \
  667. // || yaml_queue_extend((void **)&(queue).start, (void **)&(queue).head, \
  668. // (void **)&(queue).tail, (void **)&(queue).end)) ? \
  669. // (*((queue).tail++) = value, \
  670. // 1) : \
  671. // ((context)->error = yaml_MEMORY_ERROR, \
  672. // 0))
  673. //
  674. // #define DEQUEUE(context,queue) \
  675. // (*((queue).head++))
  676. //
  677. // #define QUEUE_INSERT(context,queue,index,value) \
  678. // (((queue).tail != (queue).end \
  679. // || yaml_queue_extend((void **)&(queue).start, (void **)&(queue).head, \
  680. // (void **)&(queue).tail, (void **)&(queue).end)) ? \
  681. // (memmove((queue).head+(index)+1,(queue).head+(index), \
  682. // ((queue).tail-(queue).head-(index))*sizeof(*(queue).start)), \
  683. // *((queue).head+(index)) = value, \
  684. // (queue).tail++, \
  685. // 1) : \
  686. // ((context)->error = yaml_MEMORY_ERROR, \
  687. // 0))
  688. //
  689. // /*
  690. // * Token initializers.
  691. // */
  692. //
  693. // #define TOKEN_INIT(token,token_type,token_start_mark,token_end_mark) \
  694. // (memset(&(token), 0, sizeof(yaml_token_t)), \
  695. // (token).type = (token_type), \
  696. // (token).start_mark = (token_start_mark), \
  697. // (token).end_mark = (token_end_mark))
  698. //
  699. // #define STREAM_START_TOKEN_INIT(token,token_encoding,start_mark,end_mark) \
  700. // (TOKEN_INIT((token),yaml_STREAM_START_TOKEN,(start_mark),(end_mark)), \
  701. // (token).data.stream_start.encoding = (token_encoding))
  702. //
  703. // #define STREAM_END_TOKEN_INIT(token,start_mark,end_mark) \
  704. // (TOKEN_INIT((token),yaml_STREAM_END_TOKEN,(start_mark),(end_mark)))
  705. //
  706. // #define ALIAS_TOKEN_INIT(token,token_value,start_mark,end_mark) \
  707. // (TOKEN_INIT((token),yaml_ALIAS_TOKEN,(start_mark),(end_mark)), \
  708. // (token).data.alias.value = (token_value))
  709. //
  710. // #define ANCHOR_TOKEN_INIT(token,token_value,start_mark,end_mark) \
  711. // (TOKEN_INIT((token),yaml_ANCHOR_TOKEN,(start_mark),(end_mark)), \
  712. // (token).data.anchor.value = (token_value))
  713. //
  714. // #define TAG_TOKEN_INIT(token,token_handle,token_suffix,start_mark,end_mark) \
  715. // (TOKEN_INIT((token),yaml_TAG_TOKEN,(start_mark),(end_mark)), \
  716. // (token).data.tag.handle = (token_handle), \
  717. // (token).data.tag.suffix = (token_suffix))
  718. //
  719. // #define SCALAR_TOKEN_INIT(token,token_value,token_length,token_style,start_mark,end_mark) \
  720. // (TOKEN_INIT((token),yaml_SCALAR_TOKEN,(start_mark),(end_mark)), \
  721. // (token).data.scalar.value = (token_value), \
  722. // (token).data.scalar.length = (token_length), \
  723. // (token).data.scalar.style = (token_style))
  724. //
  725. // #define VERSION_DIRECTIVE_TOKEN_INIT(token,token_major,token_minor,start_mark,end_mark) \
  726. // (TOKEN_INIT((token),yaml_VERSION_DIRECTIVE_TOKEN,(start_mark),(end_mark)), \
  727. // (token).data.version_directive.major = (token_major), \
  728. // (token).data.version_directive.minor = (token_minor))
  729. //
  730. // #define TAG_DIRECTIVE_TOKEN_INIT(token,token_handle,token_prefix,start_mark,end_mark) \
  731. // (TOKEN_INIT((token),yaml_TAG_DIRECTIVE_TOKEN,(start_mark),(end_mark)), \
  732. // (token).data.tag_directive.handle = (token_handle), \
  733. // (token).data.tag_directive.prefix = (token_prefix))
  734. //
  735. // /*
  736. // * Event initializers.
  737. // */
  738. //
  739. // #define EVENT_INIT(event,event_type,event_start_mark,event_end_mark) \
  740. // (memset(&(event), 0, sizeof(yaml_event_t)), \
  741. // (event).type = (event_type), \
  742. // (event).start_mark = (event_start_mark), \
  743. // (event).end_mark = (event_end_mark))
  744. //
  745. // #define STREAM_START_EVENT_INIT(event,event_encoding,start_mark,end_mark) \
  746. // (EVENT_INIT((event),yaml_STREAM_START_EVENT,(start_mark),(end_mark)), \
  747. // (event).data.stream_start.encoding = (event_encoding))
  748. //
  749. // #define STREAM_END_EVENT_INIT(event,start_mark,end_mark) \
  750. // (EVENT_INIT((event),yaml_STREAM_END_EVENT,(start_mark),(end_mark)))
  751. //
  752. // #define DOCUMENT_START_EVENT_INIT(event,event_version_directive, \
  753. // event_tag_directives_start,event_tag_directives_end,event_implicit,start_mark,end_mark) \
  754. // (EVENT_INIT((event),yaml_DOCUMENT_START_EVENT,(start_mark),(end_mark)), \
  755. // (event).data.document_start.version_directive = (event_version_directive), \
  756. // (event).data.document_start.tag_directives.start = (event_tag_directives_start), \
  757. // (event).data.document_start.tag_directives.end = (event_tag_directives_end), \
  758. // (event).data.document_start.implicit = (event_implicit))
  759. //
  760. // #define DOCUMENT_END_EVENT_INIT(event,event_implicit,start_mark,end_mark) \
  761. // (EVENT_INIT((event),yaml_DOCUMENT_END_EVENT,(start_mark),(end_mark)), \
  762. // (event).data.document_end.implicit = (event_implicit))
  763. //
  764. // #define ALIAS_EVENT_INIT(event,event_anchor,start_mark,end_mark) \
  765. // (EVENT_INIT((event),yaml_ALIAS_EVENT,(start_mark),(end_mark)), \
  766. // (event).data.alias.anchor = (event_anchor))
  767. //
  768. // #define SCALAR_EVENT_INIT(event,event_anchor,event_tag,event_value,event_length, \
  769. // event_plain_implicit, event_quoted_implicit,event_style,start_mark,end_mark) \
  770. // (EVENT_INIT((event),yaml_SCALAR_EVENT,(start_mark),(end_mark)), \
  771. // (event).data.scalar.anchor = (event_anchor), \
  772. // (event).data.scalar.tag = (event_tag), \
  773. // (event).data.scalar.value = (event_value), \
  774. // (event).data.scalar.length = (event_length), \
  775. // (event).data.scalar.plain_implicit = (event_plain_implicit), \
  776. // (event).data.scalar.quoted_implicit = (event_quoted_implicit), \
  777. // (event).data.scalar.style = (event_style))
  778. //
  779. // #define SEQUENCE_START_EVENT_INIT(event,event_anchor,event_tag, \
  780. // event_implicit,event_style,start_mark,end_mark) \
  781. // (EVENT_INIT((event),yaml_SEQUENCE_START_EVENT,(start_mark),(end_mark)), \
  782. // (event).data.sequence_start.anchor = (event_anchor), \
  783. // (event).data.sequence_start.tag = (event_tag), \
  784. // (event).data.sequence_start.implicit = (event_implicit), \
  785. // (event).data.sequence_start.style = (event_style))
  786. //
  787. // #define SEQUENCE_END_EVENT_INIT(event,start_mark,end_mark) \
  788. // (EVENT_INIT((event),yaml_SEQUENCE_END_EVENT,(start_mark),(end_mark)))
  789. //
  790. // #define MAPPING_START_EVENT_INIT(event,event_anchor,event_tag, \
  791. // event_implicit,event_style,start_mark,end_mark) \
  792. // (EVENT_INIT((event),yaml_MAPPING_START_EVENT,(start_mark),(end_mark)), \
  793. // (event).data.mapping_start.anchor = (event_anchor), \
  794. // (event).data.mapping_start.tag = (event_tag), \
  795. // (event).data.mapping_start.implicit = (event_implicit), \
  796. // (event).data.mapping_start.style = (event_style))
  797. //
  798. // #define MAPPING_END_EVENT_INIT(event,start_mark,end_mark) \
  799. // (EVENT_INIT((event),yaml_MAPPING_END_EVENT,(start_mark),(end_mark)))
  800. //
  801. // /*
  802. // * Document initializer.
  803. // */
  804. //
  805. // #define DOCUMENT_INIT(document,document_nodes_start,document_nodes_end, \
  806. // document_version_directive,document_tag_directives_start, \
  807. // document_tag_directives_end,document_start_implicit, \
  808. // document_end_implicit,document_start_mark,document_end_mark) \
  809. // (memset(&(document), 0, sizeof(yaml_document_t)), \
  810. // (document).nodes.start = (document_nodes_start), \
  811. // (document).nodes.end = (document_nodes_end), \
  812. // (document).nodes.top = (document_nodes_start), \
  813. // (document).version_directive = (document_version_directive), \
  814. // (document).tag_directives.start = (document_tag_directives_start), \
  815. // (document).tag_directives.end = (document_tag_directives_end), \
  816. // (document).start_implicit = (document_start_implicit), \
  817. // (document).end_implicit = (document_end_implicit), \
  818. // (document).start_mark = (document_start_mark), \
  819. // (document).end_mark = (document_end_mark))
  820. //
  821. // /*
  822. // * Node initializers.
  823. // */
  824. //
  825. // #define NODE_INIT(node,node_type,node_tag,node_start_mark,node_end_mark) \
  826. // (memset(&(node), 0, sizeof(yaml_node_t)), \
  827. // (node).type = (node_type), \
  828. // (node).tag = (node_tag), \
  829. // (node).start_mark = (node_start_mark), \
  830. // (node).end_mark = (node_end_mark))
  831. //
  832. // #define SCALAR_NODE_INIT(node,node_tag,node_value,node_length, \
  833. // node_style,start_mark,end_mark) \
  834. // (NODE_INIT((node),yaml_SCALAR_NODE,(node_tag),(start_mark),(end_mark)), \
  835. // (node).data.scalar.value = (node_value), \
  836. // (node).data.scalar.length = (node_length), \
  837. // (node).data.scalar.style = (node_style))
  838. //
  839. // #define SEQUENCE_NODE_INIT(node,node_tag,node_items_start,node_items_end, \
  840. // node_style,start_mark,end_mark) \
  841. // (NODE_INIT((node),yaml_SEQUENCE_NODE,(node_tag),(start_mark),(end_mark)), \
  842. // (node).data.sequence.items.start = (node_items_start), \
  843. // (node).data.sequence.items.end = (node_items_end), \
  844. // (node).data.sequence.items.top = (node_items_start), \
  845. // (node).data.sequence.style = (node_style))
  846. //
  847. // #define MAPPING_NODE_INIT(node,node_tag,node_pairs_start,node_pairs_end, \
  848. // node_style,start_mark,end_mark) \
  849. // (NODE_INIT((node),yaml_MAPPING_NODE,(node_tag),(start_mark),(end_mark)), \
  850. // (node).data.mapping.pairs.start = (node_pairs_start), \
  851. // (node).data.mapping.pairs.end = (node_pairs_end), \
  852. // (node).data.mapping.pairs.top = (node_pairs_start), \
  853. // (node).data.mapping.style = (node_style))
  854. //