 b72fe9e690
			
		
	
	
		b72fe9e690
		
	
	
	
	
		
			
			All the use of QOM buys us here is the ability to destroy the thing with object_unref(OBJECT(vmdesc)). Not worth the notational overhead. Signed-off-by: Markus Armbruster <armbru@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com> Reviewed-by: Dr. David Alan Gilbert <dgilbert@redhat.com> Message-Id: <1462380558-2030-3-git-send-email-armbru@redhat.com> Signed-off-by: Amit Shah <amit.shah@redhat.com>
		
			
				
	
	
		
			114 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			114 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * A simple JSON writer
 | |
|  *
 | |
|  * Copyright Alexander Graf
 | |
|  *
 | |
|  * Authors:
 | |
|  *  Alexander Graf <agraf@suse.de>
 | |
|  *
 | |
|  * 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.
 | |
|  *
 | |
|  */
 | |
| 
 | |
| /*
 | |
|  * Type QJSON lets you build JSON text.  Its interface mirrors (a
 | |
|  * subset of) abstract JSON syntax.
 | |
|  *
 | |
|  * It does *not* detect incorrect use.  It happily produces invalid
 | |
|  * JSON then.  This is what migration wants.
 | |
|  *
 | |
|  * QAPI output visitors also produce JSON text.  However, they do
 | |
|  * assert their preconditions and invariants, and therefore abort on
 | |
|  * incorrect use.
 | |
|  */
 | |
| 
 | |
| #include "qemu/osdep.h"
 | |
| #include "qapi/qmp/qstring.h"
 | |
| #include "migration/qjson.h"
 | |
| 
 | |
| struct QJSON {
 | |
|     QString *str;
 | |
|     bool omit_comma;
 | |
| };
 | |
| 
 | |
| static void json_emit_element(QJSON *json, const char *name)
 | |
| {
 | |
|     /* Check whether we need to print a , before an element */
 | |
|     if (json->omit_comma) {
 | |
|         json->omit_comma = false;
 | |
|     } else {
 | |
|         qstring_append(json->str, ", ");
 | |
|     }
 | |
| 
 | |
|     if (name) {
 | |
|         qstring_append(json->str, "\"");
 | |
|         qstring_append(json->str, name);
 | |
|         qstring_append(json->str, "\" : ");
 | |
|     }
 | |
| }
 | |
| 
 | |
| void json_start_object(QJSON *json, const char *name)
 | |
| {
 | |
|     json_emit_element(json, name);
 | |
|     qstring_append(json->str, "{ ");
 | |
|     json->omit_comma = true;
 | |
| }
 | |
| 
 | |
| void json_end_object(QJSON *json)
 | |
| {
 | |
|     qstring_append(json->str, " }");
 | |
|     json->omit_comma = false;
 | |
| }
 | |
| 
 | |
| void json_start_array(QJSON *json, const char *name)
 | |
| {
 | |
|     json_emit_element(json, name);
 | |
|     qstring_append(json->str, "[ ");
 | |
|     json->omit_comma = true;
 | |
| }
 | |
| 
 | |
| void json_end_array(QJSON *json)
 | |
| {
 | |
|     qstring_append(json->str, " ]");
 | |
|     json->omit_comma = false;
 | |
| }
 | |
| 
 | |
| void json_prop_int(QJSON *json, const char *name, int64_t val)
 | |
| {
 | |
|     json_emit_element(json, name);
 | |
|     qstring_append_int(json->str, val);
 | |
| }
 | |
| 
 | |
| void json_prop_str(QJSON *json, const char *name, const char *str)
 | |
| {
 | |
|     json_emit_element(json, name);
 | |
|     qstring_append_chr(json->str, '"');
 | |
|     qstring_append(json->str, str);
 | |
|     qstring_append_chr(json->str, '"');
 | |
| }
 | |
| 
 | |
| const char *qjson_get_str(QJSON *json)
 | |
| {
 | |
|     return qstring_get_str(json->str);
 | |
| }
 | |
| 
 | |
| QJSON *qjson_new(void)
 | |
| {
 | |
|     QJSON *json = g_new0(QJSON, 1);
 | |
| 
 | |
|     json->str = qstring_from_str("{ ");
 | |
|     json->omit_comma = true;
 | |
|     return json;
 | |
| }
 | |
| 
 | |
| void qjson_finish(QJSON *json)
 | |
| {
 | |
|     json_end_object(json);
 | |
| }
 | |
| 
 | |
| void qjson_destroy(QJSON *json)
 | |
| {
 | |
|     g_free(json);
 | |
| }
 |