The second stage of our JSON parser is a simple state machine that identifies individual JSON values by counting the levels of nesting of tokens. It does not perform grammar validation. We use this to emit a full JSON value to the parser. Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
		
			
				
	
	
		
			40 lines
		
	
	
		
			959 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
		
			959 B
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 * JSON streaming support
 | 
						|
 *
 | 
						|
 * Copyright IBM, Corp. 2009
 | 
						|
 *
 | 
						|
 * Authors:
 | 
						|
 *  Anthony Liguori   <aliguori@us.ibm.com>
 | 
						|
 *
 | 
						|
 * This work is licensed under the terms of the GNU LGPL, version 2.1 or later.
 | 
						|
 * See the COPYING.LIB file in the top-level directory.
 | 
						|
 *
 | 
						|
 */
 | 
						|
 | 
						|
#ifndef QEMU_JSON_STREAMER_H
 | 
						|
#define QEMU_JSON_STREAMER_H
 | 
						|
 | 
						|
#include "qlist.h"
 | 
						|
#include "json-lexer.h"
 | 
						|
 | 
						|
typedef struct JSONMessageParser
 | 
						|
{
 | 
						|
    void (*emit)(struct JSONMessageParser *parser, QList *tokens);
 | 
						|
    JSONLexer lexer;
 | 
						|
    int brace_count;
 | 
						|
    int bracket_count;
 | 
						|
    QList *tokens;
 | 
						|
} JSONMessageParser;
 | 
						|
 | 
						|
void json_message_parser_init(JSONMessageParser *parser,
 | 
						|
                              void (*func)(JSONMessageParser *, QList *));
 | 
						|
 | 
						|
int json_message_parser_feed(JSONMessageParser *parser,
 | 
						|
                             const char *buffer, size_t size);
 | 
						|
 | 
						|
int json_message_parser_flush(JSONMessageParser *parser);
 | 
						|
 | 
						|
void json_message_parser_destroy(JSONMessageParser *parser);
 | 
						|
 | 
						|
#endif
 |