Ejemplo n.º 1
0
static int
yaml_parser_parse_block_mapping_value(yaml_parser_t *parser,
                                      yaml_event_t *event)
{
    yaml_token_t *token;

    token = PEEK_TOKEN(parser);
    if (!token) return 0;

    if (token->type == YAML_VALUE_TOKEN)
    {
        yaml_mark_t mark = token->end_mark;
        SKIP_TOKEN(parser);
        token = PEEK_TOKEN(parser);
        if (!token) return 0;
        if (token->type != YAML_KEY_TOKEN &&
                token->type != YAML_VALUE_TOKEN &&
                token->type != YAML_BLOCK_END_TOKEN) {
            if (!PUSH(parser, parser->states,
                      YAML_PARSE_BLOCK_MAPPING_KEY_STATE))
                return 0;
            return yaml_parser_parse_node(parser, event, 1, 1);
        }
        else {
            parser->state = YAML_PARSE_BLOCK_MAPPING_KEY_STATE;
            return yaml_parser_process_empty_scalar(parser, event, mark);
        }
    }

    else
    {
        parser->state = YAML_PARSE_BLOCK_MAPPING_KEY_STATE;
        return yaml_parser_process_empty_scalar(parser, event, token->start_mark);
    }
}
Ejemplo n.º 2
0
Archivo: parser.c Proyecto: 274914765/C
static int yaml_parser_parse_indentless_sequence_entry (yaml_parser_t * parser, yaml_event_t * event)
{
    yaml_token_t *token;

    token = PEEK_TOKEN (parser);
    if (!token)
	return 0;

    if (token->type == YAML_BLOCK_ENTRY_TOKEN)
	{
	    yaml_mark_t mark = token->end_mark;
	    SKIP_TOKEN (parser);
	    token = PEEK_TOKEN (parser);
	    if (!token)
		return 0;
	    if (token->type != YAML_BLOCK_ENTRY_TOKEN && token->type != YAML_KEY_TOKEN && token->type != YAML_VALUE_TOKEN && token->type != YAML_BLOCK_END_TOKEN)
		{
		    if (!PUSH (parser, parser->states, YAML_PARSE_INDENTLESS_SEQUENCE_ENTRY_STATE))
			return 0;
		    return yaml_parser_parse_node (parser, event, 1, 0);
		}
	    else
		{
		    parser->state = YAML_PARSE_INDENTLESS_SEQUENCE_ENTRY_STATE;
		    return yaml_parser_process_empty_scalar (parser, event, mark);
		}
	}

    else
	{
	    parser->state = POP (parser, parser->states);
	    SEQUENCE_END_EVENT_INIT (*event, token->start_mark, token->start_mark);
	    return 1;
	}
}
Ejemplo n.º 3
0
static int
yaml_parser_parse_flow_mapping_value(yaml_parser_t *parser,
                                     yaml_event_t *event, int empty)
{
    yaml_token_t *token;

    token = PEEK_TOKEN(parser);
    if (!token) return 0;

    if (empty) {
        parser->state = YAML_PARSE_FLOW_MAPPING_KEY_STATE;
        return yaml_parser_process_empty_scalar(parser, event,
                                                token->start_mark);
    }

    if (token->type == YAML_VALUE_TOKEN) {
        SKIP_TOKEN(parser);
        token = PEEK_TOKEN(parser);
        if (!token) return 0;
        if (token->type != YAML_FLOW_ENTRY_TOKEN
                && token->type != YAML_FLOW_MAPPING_END_TOKEN) {
            if (!PUSH(parser, parser->states,
                      YAML_PARSE_FLOW_MAPPING_KEY_STATE))
                return 0;
            return yaml_parser_parse_node(parser, event, 0, 0);
        }
    }

    parser->state = YAML_PARSE_FLOW_MAPPING_KEY_STATE;
    return yaml_parser_process_empty_scalar(parser, event, token->start_mark);
}
Ejemplo n.º 4
0
Archivo: parser.c Proyecto: 274914765/C
static int yaml_parser_parse_flow_sequence_entry (yaml_parser_t * parser, yaml_event_t * event, int first)
{
    yaml_token_t *token;
    yaml_mark_t dummy_mark;	/* Used to eliminate a compiler warning. */

    if (first)
	{
	    token = PEEK_TOKEN (parser);
	    if (!PUSH (parser, parser->marks, token->start_mark))
		return 0;
	    SKIP_TOKEN (parser);
	}

    token = PEEK_TOKEN (parser);
    if (!token)
	return 0;

    if (token->type != YAML_FLOW_SEQUENCE_END_TOKEN)
	{
	    if (!first)
		{
		    if (token->type == YAML_FLOW_ENTRY_TOKEN)
			{
			    SKIP_TOKEN (parser);
			    token = PEEK_TOKEN (parser);
			    if (!token)
				return 0;
			}
		    else
			{
			    return yaml_parser_set_parser_error_context (parser, "while parsing a flow sequence", POP (parser, parser->marks), "did not find expected ',' or ']'", token->start_mark);
			}
		}

	    if (token->type == YAML_KEY_TOKEN)
		{
		    parser->state = YAML_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_KEY_STATE;
		    MAPPING_START_EVENT_INIT (*event, NULL, NULL, 1, YAML_FLOW_MAPPING_STYLE, token->start_mark, token->end_mark);
		    SKIP_TOKEN (parser);
		    return 1;
		}

	    else if (token->type != YAML_FLOW_SEQUENCE_END_TOKEN)
		{
		    if (!PUSH (parser, parser->states, YAML_PARSE_FLOW_SEQUENCE_ENTRY_STATE))
			return 0;
		    return yaml_parser_parse_node (parser, event, 0, 0);
		}
	}

    parser->state = POP (parser, parser->states);
    dummy_mark = POP (parser, parser->marks);
    SEQUENCE_END_EVENT_INIT (*event, token->start_mark, token->end_mark);
    SKIP_TOKEN (parser);
    return 1;
}
Ejemplo n.º 5
0
static int
yaml_parser_parse_block_mapping_key(yaml_parser_t *parser,
        yaml_event_t *event, int first)
{
    yaml_token_t *token;

    if (first) {
        token = PEEK_TOKEN(parser);
        if (!PUSH(parser, parser->marks, token->start_mark))
            return 0;
        SKIP_TOKEN(parser);
    }

    token = PEEK_TOKEN(parser);
    if (!token) return 0;

    if (token->type == YAML_KEY_TOKEN)
    {
        yaml_mark_t mark = token->end_mark;
        SKIP_TOKEN(parser);
        token = PEEK_TOKEN(parser);
        if (!token) return 0;
        if (token->type != YAML_KEY_TOKEN &&
                token->type != YAML_VALUE_TOKEN &&
                token->type != YAML_BLOCK_END_TOKEN) {
            if (!PUSH(parser, parser->states,
                        YAML_PARSE_BLOCK_MAPPING_VALUE_STATE))
                return 0;
            return yaml_parser_parse_node(parser, event, 1, 1);
        }
        else {
            parser->state = YAML_PARSE_BLOCK_MAPPING_VALUE_STATE;
            return yaml_parser_process_empty_scalar(parser, event, mark);
        }
    }

    else if (token->type == YAML_BLOCK_END_TOKEN)
    {
        yaml_mark_t dummy_mark;     /* Used to eliminate a compiler warning. */
        parser->state = POP(parser, parser->states);
        dummy_mark = POP(parser, parser->marks);
        MAPPING_END_EVENT_INIT(*event, token->start_mark, token->end_mark);
        SKIP_TOKEN(parser);
        return 1;
    }

    else
    {
        return yaml_parser_set_parser_error_context(parser,
                "while parsing a block mapping", POP(parser, parser->marks),
                "did not find expected key", token->start_mark);
    }
}
Ejemplo n.º 6
0
static int
yaml_parser_parse_block_sequence_entry(yaml_parser_t *parser,
                                       yaml_event_t *event, int first)
{
    yaml_token_t *token;

    if (first) {
        token = PEEK_TOKEN(parser);
        if (!PUSH(parser, parser->marks, token->start_mark))
            return 0;
        SKIP_TOKEN(parser);
    }

    token = PEEK_TOKEN(parser);
    if (!token) return 0;

    if (token->type == YAML_BLOCK_ENTRY_TOKEN)
    {
        yaml_mark_t mark = token->end_mark;
        SKIP_TOKEN(parser);
        token = PEEK_TOKEN(parser);
        if (!token) return 0;
        if (token->type != YAML_BLOCK_ENTRY_TOKEN &&
                token->type != YAML_BLOCK_END_TOKEN) {
            if (!PUSH(parser, parser->states,
                      YAML_PARSE_BLOCK_SEQUENCE_ENTRY_STATE))
                return 0;
            return yaml_parser_parse_node(parser, event, 1, 0);
        }
        else {
            parser->state = YAML_PARSE_BLOCK_SEQUENCE_ENTRY_STATE;
            return yaml_parser_process_empty_scalar(parser, event, mark);
        }
    }

    else if (token->type == YAML_BLOCK_END_TOKEN)
    {
        yaml_mark_t dummy_mark;     /* Used to eliminate a compiler warning. */
        parser->state = POP(parser, parser->states);
        dummy_mark = POP(parser, parser->marks);
        SEQUENCE_END_EVENT_INIT(*event, token->start_mark, token->end_mark);
        SKIP_TOKEN(parser);
        return 1;
    }

    else
    {
        return yaml_parser_set_parser_error_context(parser,
                "while parsing a block collection", POP(parser, parser->marks),
                "did not find expected '-' indicator", token->start_mark);
    }
}
Ejemplo n.º 7
0
Archivo: parser.c Proyecto: 274914765/C
static int yaml_parser_parse_document_content (yaml_parser_t * parser, yaml_event_t * event)
{
    yaml_token_t *token;

    token = PEEK_TOKEN (parser);
    if (!token)
	return 0;

    if (token->type == YAML_VERSION_DIRECTIVE_TOKEN ||
	token->type == YAML_TAG_DIRECTIVE_TOKEN || token->type == YAML_DOCUMENT_START_TOKEN || token->type == YAML_DOCUMENT_END_TOKEN || token->type == YAML_STREAM_END_TOKEN)
	{
	    parser->state = POP (parser, parser->states);
	    return yaml_parser_process_empty_scalar (parser, event, token->start_mark);
	}
    else
	{
	    return yaml_parser_parse_node (parser, event, 1, 0);
	}
}
Ejemplo n.º 8
0
Archivo: parser.c Proyecto: 274914765/C
static int yaml_parser_parse_flow_sequence_entry_mapping_key (yaml_parser_t * parser, yaml_event_t * event)
{
    yaml_token_t *token;

    token = PEEK_TOKEN (parser);
    if (!token)
	return 0;

    if (token->type != YAML_VALUE_TOKEN && token->type != YAML_FLOW_ENTRY_TOKEN && token->type != YAML_FLOW_SEQUENCE_END_TOKEN)
	{
	    if (!PUSH (parser, parser->states, YAML_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_VALUE_STATE))
		return 0;
	    return yaml_parser_parse_node (parser, event, 0, 0);
	}
    else
	{
	    yaml_mark_t mark = token->end_mark;
	    SKIP_TOKEN (parser);
	    parser->state = YAML_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_VALUE_STATE;
	    return yaml_parser_process_empty_scalar (parser, event, mark);
	}
}
Ejemplo n.º 9
0
static int
yaml_parser_state_machine(yaml_parser_t *parser, yaml_event_t *event)
{
    switch (parser->state)
    {
    case YAML_PARSE_STREAM_START_STATE:
        return yaml_parser_parse_stream_start(parser, event);

    case YAML_PARSE_IMPLICIT_DOCUMENT_START_STATE:
        return yaml_parser_parse_document_start(parser, event, 1);

    case YAML_PARSE_DOCUMENT_START_STATE:
        return yaml_parser_parse_document_start(parser, event, 0);

    case YAML_PARSE_DOCUMENT_CONTENT_STATE:
        return yaml_parser_parse_document_content(parser, event);

    case YAML_PARSE_DOCUMENT_END_STATE:
        return yaml_parser_parse_document_end(parser, event);

    case YAML_PARSE_BLOCK_NODE_STATE:
        return yaml_parser_parse_node(parser, event, 1, 0);

    case YAML_PARSE_BLOCK_NODE_OR_INDENTLESS_SEQUENCE_STATE:
        return yaml_parser_parse_node(parser, event, 1, 1);

    case YAML_PARSE_FLOW_NODE_STATE:
        return yaml_parser_parse_node(parser, event, 0, 0);

    case YAML_PARSE_BLOCK_SEQUENCE_FIRST_ENTRY_STATE:
        return yaml_parser_parse_block_sequence_entry(parser, event, 1);

    case YAML_PARSE_BLOCK_SEQUENCE_ENTRY_STATE:
        return yaml_parser_parse_block_sequence_entry(parser, event, 0);

    case YAML_PARSE_INDENTLESS_SEQUENCE_ENTRY_STATE:
        return yaml_parser_parse_indentless_sequence_entry(parser, event);

    case YAML_PARSE_BLOCK_MAPPING_FIRST_KEY_STATE:
        return yaml_parser_parse_block_mapping_key(parser, event, 1);

    case YAML_PARSE_BLOCK_MAPPING_KEY_STATE:
        return yaml_parser_parse_block_mapping_key(parser, event, 0);

    case YAML_PARSE_BLOCK_MAPPING_VALUE_STATE:
        return yaml_parser_parse_block_mapping_value(parser, event);

    case YAML_PARSE_FLOW_SEQUENCE_FIRST_ENTRY_STATE:
        return yaml_parser_parse_flow_sequence_entry(parser, event, 1);

    case YAML_PARSE_FLOW_SEQUENCE_ENTRY_STATE:
        return yaml_parser_parse_flow_sequence_entry(parser, event, 0);

    case YAML_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_KEY_STATE:
        return yaml_parser_parse_flow_sequence_entry_mapping_key(parser, event);

    case YAML_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_VALUE_STATE:
        return yaml_parser_parse_flow_sequence_entry_mapping_value(parser, event);

    case YAML_PARSE_FLOW_SEQUENCE_ENTRY_MAPPING_END_STATE:
        return yaml_parser_parse_flow_sequence_entry_mapping_end(parser, event);

    case YAML_PARSE_FLOW_MAPPING_FIRST_KEY_STATE:
        return yaml_parser_parse_flow_mapping_key(parser, event, 1);

    case YAML_PARSE_FLOW_MAPPING_KEY_STATE:
        return yaml_parser_parse_flow_mapping_key(parser, event, 0);

    case YAML_PARSE_FLOW_MAPPING_VALUE_STATE:
        return yaml_parser_parse_flow_mapping_value(parser, event, 0);

    case YAML_PARSE_FLOW_MAPPING_EMPTY_VALUE_STATE:
        return yaml_parser_parse_flow_mapping_value(parser, event, 1);

    default:
        assert(1);      /* Invalid state. */
    }

    return 0;
}
Ejemplo n.º 10
0
static int
yaml_parser_parse_flow_mapping_key(yaml_parser_t *parser,
        yaml_event_t *event, int first)
{
    yaml_token_t *token;

    if (first) {
        token = PEEK_TOKEN(parser);
        if (!token || !PUSH(parser, parser->marks, token->start_mark))
            return 0;
        SKIP_TOKEN(parser);
    }

    token = PEEK_TOKEN(parser);
    if (!token) return 0;

    if (token->type != YAML_FLOW_MAPPING_END_TOKEN)
    {
        if (!first) {
            if (token->type == YAML_FLOW_ENTRY_TOKEN) {
                SKIP_TOKEN(parser);
                token = PEEK_TOKEN(parser);
                if (!token) return 0;
            }
            else {
                return yaml_parser_set_parser_error_context(parser,
                        "while parsing a flow mapping", POP(parser, parser->marks),
                        "did not find expected ',' or '}'", token->start_mark);
            }
        }

        if (token->type == YAML_KEY_TOKEN) {
            SKIP_TOKEN(parser);
            token = PEEK_TOKEN(parser);
            if (!token) return 0;
            if (token->type != YAML_VALUE_TOKEN
                    && token->type != YAML_FLOW_ENTRY_TOKEN
                    && token->type != YAML_FLOW_MAPPING_END_TOKEN) {
                if (!PUSH(parser, parser->states,
                            YAML_PARSE_FLOW_MAPPING_VALUE_STATE))
                    return 0;
                return yaml_parser_parse_node(parser, event, 0, 0);
            }
            else {
                parser->state = YAML_PARSE_FLOW_MAPPING_VALUE_STATE;
                return yaml_parser_process_empty_scalar(parser, event,
                        token->start_mark);
            }
        }
        else if (token->type != YAML_FLOW_MAPPING_END_TOKEN) {
            if (!PUSH(parser, parser->states,
                        YAML_PARSE_FLOW_MAPPING_EMPTY_VALUE_STATE))
                return 0;
            return yaml_parser_parse_node(parser, event, 0, 0);
        }
    }

    parser->state = POP(parser, parser->states);
    POP(parser, parser->marks);
    MAPPING_END_EVENT_INIT(*event, token->start_mark, token->end_mark);
    SKIP_TOKEN(parser);
    return 1;
}