48 #define PEEK_TOKEN(parser) \ 49 ((parser->token_available || yaml_parser_fetch_more_tokens(parser)) ? \ 50 parser->tokens.head : NULL) 56 #define SKIP_TOKEN(parser) \ 57 (parser->token_available = 0, \ 58 parser->tokens_parsed ++, \ 59 parser->stream_end_produced = \ 60 (parser->tokens.head->type == YAML_STREAM_END_TOKEN), \ 61 parser->tokens.head ++) 105 int block,
int indentless_sequence);
108 yaml_parser_parse_block_sequence_entry(
yaml_parser_t *parser,
112 yaml_parser_parse_indentless_sequence_entry(
yaml_parser_t *parser,
128 yaml_parser_parse_flow_sequence_entry_mapping_key(
yaml_parser_t *parser,
132 yaml_parser_parse_flow_sequence_entry_mapping_value(
yaml_parser_t *parser,
136 yaml_parser_parse_flow_sequence_entry_mapping_end(
yaml_parser_t *parser,
181 if (parser->stream_end_produced || parser->error ||
188 return yaml_parser_state_machine(parser, event);
228 switch (parser->
state)
231 return yaml_parser_parse_stream_start(parser, event);
234 return yaml_parser_parse_document_start(parser, event, 1);
237 return yaml_parser_parse_document_start(parser, event, 0);
240 return yaml_parser_parse_document_content(parser, event);
243 return yaml_parser_parse_document_end(parser, event);
246 return yaml_parser_parse_node(parser, event, 1, 0);
249 return yaml_parser_parse_node(parser, event, 1, 1);
252 return yaml_parser_parse_node(parser, event, 0, 0);
255 return yaml_parser_parse_block_sequence_entry(parser, event, 1);
258 return yaml_parser_parse_block_sequence_entry(parser, event, 0);
261 return yaml_parser_parse_indentless_sequence_entry(parser, event);
264 return yaml_parser_parse_block_mapping_key(parser, event, 1);
267 return yaml_parser_parse_block_mapping_key(parser, event, 0);
270 return yaml_parser_parse_block_mapping_value(parser, event);
273 return yaml_parser_parse_flow_sequence_entry(parser, event, 1);
276 return yaml_parser_parse_flow_sequence_entry(parser, event, 0);
279 return yaml_parser_parse_flow_sequence_entry_mapping_key(parser, event);
282 return yaml_parser_parse_flow_sequence_entry_mapping_value(parser, event);
285 return yaml_parser_parse_flow_sequence_entry_mapping_end(parser, event);
288 return yaml_parser_parse_flow_mapping_key(parser, event, 1);
291 return yaml_parser_parse_flow_mapping_key(parser, event, 0);
294 return yaml_parser_parse_flow_mapping_value(parser, event, 0);
297 return yaml_parser_parse_flow_mapping_value(parser, event, 1);
318 if (!token)
return 0;
321 return yaml_parser_set_parser_error(parser,
322 "did not find expected <stream-start>", token->
start_mark);
350 } tag_directives = { NULL, NULL };
353 if (!token)
return 0;
362 if (!token)
return 0;
373 if (!yaml_parser_process_directives(parser, NULL, NULL, NULL))
389 if (!yaml_parser_process_directives(parser, &version_directive,
390 &tag_directives.start, &tag_directives.end))
393 if (!token)
goto error;
395 yaml_parser_set_parser_error(parser,
396 "did not find expected <document start>", token->
start_mark);
404 tag_directives.start, tag_directives.end, 0,
405 start_mark, end_mark);
407 version_directive = NULL;
408 tag_directives.start = tag_directives.end = NULL;
424 while (tag_directives.start != tag_directives.end) {
425 yaml_free(tag_directives.end[-1].handle);
426 yaml_free(tag_directives.end[-1].prefix);
427 tag_directives.end --;
445 if (!token)
return 0;
453 return yaml_parser_process_empty_scalar(parser, event,
457 return yaml_parser_parse_node(parser, event, 1, 0);
477 if (!token)
return 0;
530 int block,
int indentless_sequence)
541 if (!token)
return 0;
563 if (!token)
goto error;
566 tag_handle = token->
data.
tag.handle;
567 tag_suffix = token->
data.
tag.suffix;
572 if (!token)
goto error;
577 tag_handle = token->
data.
tag.handle;
578 tag_suffix = token->
data.
tag.suffix;
583 if (!token)
goto error;
590 if (!token)
goto error;
598 tag_handle = tag_suffix = NULL;
605 if (strcmp((
char *)tag_directive->
handle, (
char *)tag_handle) == 0) {
606 size_t prefix_len = strlen((
char *)tag_directive->
prefix);
607 size_t suffix_len = strlen((
char *)tag_suffix);
613 memcpy(tag, tag_directive->
prefix, prefix_len);
614 memcpy(tag+prefix_len, tag_suffix, suffix_len);
615 tag[prefix_len+suffix_len] =
'\0';
618 tag_handle = tag_suffix = NULL;
623 yaml_parser_set_parser_error_context(parser,
624 "while parsing a node", start_mark,
625 "found undefined tag handle", tag_mark);
631 implicit = (!tag || !*tag);
641 int plain_implicit = 0;
642 int quoted_implicit = 0;
645 || (tag && strcmp((
char *)tag,
"!") == 0)) {
654 plain_implicit, quoted_implicit,
655 token->
data.
scalar.style, start_mark, end_mark);
687 else if (anchor || tag) {
697 start_mark, end_mark);
701 yaml_parser_set_parser_error_context(parser,
702 (block ?
"while parsing a block node" 703 :
"while parsing a flow node"), start_mark,
704 "did not find expected node content", token->
start_mark);
726 yaml_parser_parse_block_sequence_entry(
yaml_parser_t *parser,
739 if (!token)
return 0;
746 if (!token)
return 0;
752 return yaml_parser_parse_node(parser, event, 1, 0);
756 return yaml_parser_process_empty_scalar(parser, event, mark);
771 return yaml_parser_set_parser_error_context(parser,
772 "while parsing a block collection",
POP(parser, parser->
marks),
773 "did not find expected '-' indicator", token->
start_mark);
784 yaml_parser_parse_indentless_sequence_entry(
yaml_parser_t *parser,
790 if (!token)
return 0;
797 if (!token)
return 0;
805 return yaml_parser_parse_node(parser, event, 1, 0);
809 return yaml_parser_process_empty_scalar(parser, event, mark);
847 if (!token)
return 0;
854 if (!token)
return 0;
861 return yaml_parser_parse_node(parser, event, 1, 1);
865 return yaml_parser_process_empty_scalar(parser, event, mark);
880 return yaml_parser_set_parser_error_context(parser,
881 "while parsing a block mapping",
POP(parser, parser->
marks),
882 "did not find expected key", token->
start_mark);
905 if (!token)
return 0;
912 if (!token)
return 0;
919 return yaml_parser_parse_node(parser, event, 1, 1);
923 return yaml_parser_process_empty_scalar(parser, event, mark);
930 return yaml_parser_process_empty_scalar(parser, event, token->
start_mark);
962 if (!token)
return 0;
970 if (!token)
return 0;
973 return yaml_parser_set_parser_error_context(parser,
974 "while parsing a flow sequence",
POP(parser, parser->
marks),
975 "did not find expected ',' or ']'", token->
start_mark);
992 return yaml_parser_parse_node(parser, event, 0, 0);
1010 yaml_parser_parse_flow_sequence_entry_mapping_key(
yaml_parser_t *parser,
1016 if (!token)
return 0;
1023 return yaml_parser_parse_node(parser, event, 0, 0);
1029 return yaml_parser_process_empty_scalar(parser, event, mark);
1040 yaml_parser_parse_flow_sequence_entry_mapping_value(
yaml_parser_t *parser,
1046 if (!token)
return 0;
1051 if (!token)
return 0;
1057 return yaml_parser_parse_node(parser, event, 0, 0);
1061 return yaml_parser_process_empty_scalar(parser, event, token->
start_mark);
1071 yaml_parser_parse_flow_sequence_entry_mapping_end(
yaml_parser_t *parser,
1077 if (!token)
return 0;
1113 if (!token)
return 0;
1121 if (!token)
return 0;
1124 return yaml_parser_set_parser_error_context(parser,
1125 "while parsing a flow mapping",
POP(parser, parser->
marks),
1126 "did not find expected ',' or '}'", token->
start_mark);
1133 if (!token)
return 0;
1140 return yaml_parser_parse_node(parser, event, 0, 0);
1144 return yaml_parser_process_empty_scalar(parser, event,
1152 return yaml_parser_parse_node(parser, event, 0, 0);
1176 if (!token)
return 0;
1180 return yaml_parser_process_empty_scalar(parser, event,
1187 if (!token)
return 0;
1193 return yaml_parser_parse_node(parser, event, 0, 0);
1198 return yaml_parser_process_empty_scalar(parser, event, token->
start_mark);
1245 } tag_directives = { NULL, NULL, NULL };
1252 if (!token)
goto error;
1258 if (version_directive) {
1259 yaml_parser_set_parser_error(parser,
1260 "found duplicate %YAML directive", token->
start_mark);
1268 yaml_parser_set_parser_error(parser,
1269 "found incompatible YAML document", token->
start_mark);
1273 if (!version_directive) {
1286 if (!yaml_parser_append_tag_directive(parser, value, 0,
1289 if (!
PUSH(parser, tag_directives, value))
1295 if (!token)
goto error;
1298 for (default_tag_directive = default_tag_directives;
1299 default_tag_directive->
handle; default_tag_directive++) {
1300 if (!yaml_parser_append_tag_directive(parser, *default_tag_directive, 1,
1305 if (version_directive_ref) {
1306 *version_directive_ref = version_directive;
1308 if (tag_directives_start_ref) {
1310 *tag_directives_start_ref = *tag_directives_end_ref = NULL;
1314 *tag_directives_start_ref = tag_directives.start;
1315 *tag_directives_end_ref = tag_directives.top;
1322 if (!version_directive_ref)
1350 if (strcmp((
char *)value.
handle, (
char *)tag_directive->
handle) == 0) {
1351 if (allow_duplicates)
1353 return yaml_parser_set_parser_error(parser,
1354 "found duplicate %TAG directive", mark);
#define MAPPING_START_EVENT_INIT(event, event_anchor, event_tag, event_implicit, event_style, start_mark, end_mark)
Expect an entry of a flow sequence.
A BLOCK-SEQUENCE-START token.
yaml_parser_parse(yaml_parser_t *parser, yaml_event_t *event)
Parse the input stream and produce the next parsing event.
#define STREAM_END_EVENT_INIT(event, start_mark, end_mark)
struct yaml_token_s::@9::@15 version_directive
The version directive (for YAML_VERSION_DIRECTIVE_TOKEN).
A FLOW-SEQUENCE-START token.
Expect the first key of a block mapping.
Cannot allocate or reallocate a block of memory.
yaml_mark_t end_mark
The end of the token.
A BLOCK-MAPPING-START token.
#define STREAM_START_EVENT_INIT(event, event_encoding, start_mark, end_mark)
yaml_parser_state_t state
The current parser state.
unsigned char yaml_char_t
The character type (UTF-8 octet).
const unsigned char * start
The string start pointer.
The version directive data.
const char * context
The error context.
Expect a key of an ordered mapping.
yaml_char_t * prefix
The tag prefix.
#define PUSH(context, stack, value)
#define SEQUENCE_END_EVENT_INIT(event, start_mark, end_mark)
Expect the beginning of an implicit document.
A FLOW-SEQUENCE-END token.
#define STACK_EMPTY(context, stack)
Expect the content of a document.
int * top
The top of the stack.
A VERSION-DIRECTIVE token.
int copy(const char *src, const char *dst)
copy files recursively This function is equivalent to 'cp -Ra' without wildcards and circular link de...
int major
The major version number.
Expect an entry of a block sequence.
#define ALIAS_EVENT_INIT(event, event_anchor, start_mark, end_mark)
#define YAML_DECLARE(type)
The public API declaration.
A FLOW-MAPPING-START token.
#define STACK_DEL(context, stack)
struct yaml_parser_s::@40 states
The parser states stack.
yaml_error_type_t error
Error type.
#define DOCUMENT_END_EVENT_INIT(event, event_implicit, start_mark, end_mark)
#define MAPPING_END_EVENT_INIT(event, start_mark, end_mark)
struct yaml_parser_s::@42 tag_directives
The list of TAG directives.
#define SEQUENCE_START_EVENT_INIT(event, event_anchor, event_tag, event_implicit, event_style, start_mark, end_mark)
yaml_char_t * handle
The tag handle.
Expect a block mapping value.
#define PEEK_TOKEN(parser)
struct yaml_token_s::@9::@12 anchor
The anchor (for YAML_ANCHOR_TOKEN).
yaml_token_type_t type
The token type.
struct yaml_token_s::@9::@14 scalar
The scalar value (for YAML_SCALAR_TOKEN).
struct yaml_token_s::@9::@16 tag_directive
The tag directive (for YAML_TAG_DIRECTIVE_TOKEN).
Cannot parse the input stream.
struct yaml_token_s::@9::@10 stream_start
The stream start (for YAML_STREAM_START_TOKEN).
Expect an empty value of a flow mapping.
yaml_mark_t context_mark
The context position.
yaml_strdup(const yaml_char_t *)
struct yaml_token_s::@9::@11 alias
The alias (for YAML_ALIAS_TOKEN).
A FLOW-MAPPING-END token.
yaml_mark_t problem_mark
The problem position.
#define YAML_MALLOC(size)
Expect the and of an ordered mapping entry.
Expect an entry of an indentless sequence.
Expect a block node or indentless sequence.
#define YAML_MALLOC_STATIC(type)
#define SKIP_TOKEN(parser)
int minor
The minor version number.
Expect the first entry of a flow sequence.
#define POP(context, stack)
struct yaml_parser_s::@41 marks
The stack of marks.
Expect the first entry of a block sequence.
Expect a value of a flow mapping.
#define DOCUMENT_START_EVENT_INIT(event, event_version_directive, event_tag_directives_start, event_tag_directives_end, event_implicit, start_mark, end_mark)
Expect a key of a flow mapping.
Expect the first key of a flow mapping.
const char * problem
Error description.
Expect a value of an ordered mapping.
#define SCALAR_EVENT_INIT(event, event_anchor, event_tag, event_value, event_length, event_plain_implicit, event_quoted_implicit, event_style, start_mark, end_mark)
#define STACK_INIT(context, stack, type)
union yaml_token_s::@9 data
The token data.
Expect a block mapping key.
struct yaml_token_s::@9::@13 tag
The tag (for YAML_TAG_TOKEN).
The block sequence style.
yaml_mark_t start_mark
The beginning of the token.