diff --git a/cJSON.c b/cJSON.c index 426683d..dc2f4fd 100644 --- a/cJSON.c +++ b/cJSON.c @@ -1211,39 +1211,98 @@ static char *print_array(cJSON *item, int depth, int fmt, printbuffer *p) } /* Build an object from the text. */ -static const char *parse_object(cJSON *item,const char *value,const char **ep) +static const char *parse_object(cJSON *item, const char *value, const char **ep) { - cJSON *child; - if (*value!='{') {*ep=value;return 0;} /* not an object! */ - - item->type=cJSON_Object; - value=skip(value+1); - if (*value=='}') return value+1; /* empty array. */ - - item->child=child=cJSON_New_Item(); - if (!item->child) return 0; - value=skip(parse_string(child,skip(value),ep)); - if (!value) return 0; - child->string=child->valuestring;child->valuestring=0; - if (*value!=':') {*ep=value;return 0;} /* fail! */ - value=skip(parse_value(child,skip(value+1),ep)); /* skip any spacing, get the value. */ - if (!value) return 0; - - while (*value==',') - { - cJSON *new_item; - if (!(new_item=cJSON_New_Item())) return 0; /* memory fail */ - child->next=new_item;new_item->prev=child;child=new_item; - value=skip(parse_string(child,skip(value+1),ep)); - if (!value) return 0; - child->string=child->valuestring;child->valuestring=0; - if (*value!=':') {*ep=value;return 0;} /* fail! */ - value=skip(parse_value(child,skip(value+1),ep)); /* skip any spacing, get the value. */ - if (!value) return 0; - } - - if (*value=='}') return value+1; /* end of array */ - *ep=value;return 0; /* malformed. */ + cJSON *child; + if (*value != '{') + { + /* not an object! */ + *ep = value; + return 0; + } + + item->type = cJSON_Object; + value = skip(value + 1); + if (*value == '}') + { + /* empty object. */ + return value + 1; + } + + child = cJSON_New_Item(); + item->child = child; + if (!item->child) + { + return 0; + } + /* parse first key */ + value = skip(parse_string(child, skip(value), ep)); + if (!value) + { + return 0; + } + /* use string as key, not value */ + child->string = child->valuestring; + child->valuestring = 0; + + if (*value != ':') + { + /* invalid object. */ + *ep = value; + return 0; + } + /* skip any spacing, get the value. */ + value = skip(parse_value(child, skip(value + 1), ep)); + if (!value) + { + return 0; + } + + while (*value == ',') + { + cJSON *new_item; + if (!(new_item = cJSON_New_Item())) + { + /* memory fail */ + return 0; + } + /* add to linked list */ + child->next = new_item; + new_item->prev = child; + + child = new_item; + value = skip(parse_string(child, skip(value + 1), ep)); + if (!value) + { + return 0; + } + + /* use string as key, not value */ + child->string = child->valuestring; + child->valuestring = 0; + + if (*value != ':') + { + /* invalid object. */ + *ep = value; + return 0; + } + /* skip any spacing, get the value. */ + value = skip(parse_value(child, skip(value + 1), ep)); + if (!value) + { + return 0; + } + } + /* end of object */ + if (*value == '}') + { + return value + 1; + } + + /* malformed */ + *ep = value; + return 0; } /* Render an object to text. */