summaryrefslogtreecommitdiff
path: root/jsmn.c
diff options
context:
space:
mode:
authorSerge A. Zaitsev <devnull@localhost>2010-12-28 11:16:41 +0200
committerSerge A. Zaitsev <devnull@localhost>2010-12-28 11:16:41 +0200
commit4e869f7e9e3121ee84b8a3b65806143f7c8672ab (patch)
tree0d05ba13257e06321a669db03ab12cc56fc8d8aa /jsmn.c
parentc4d9412483bc561cef53a784e9f28b827e010e7b (diff)
Complex types (objects and arrays) now have also size - number of child elements
Diffstat (limited to 'jsmn.c')
-rw-r--r--jsmn.c19
1 files changed, 18 insertions, 1 deletions
diff --git a/jsmn.c b/jsmn.c
index 3f2b149c2..9907e27ea 100644
--- a/jsmn.c
+++ b/jsmn.c
@@ -11,6 +11,7 @@ static jsmntok_t *jsmn_get_token(jsmn_parser *parser) {
for (i = parser->curtoken; i<parser->num_tokens; i++) {
if (tokens[i].start == -1 && tokens[i].end == -1) {
parser->curtoken = i;
+ tokens[i].size = 0;
return &tokens[i];
}
}
@@ -40,6 +41,7 @@ void jsmn_init_parser(jsmn_parser *parser, const char *js,
parser->tokens = tokens;
parser->num_tokens = num_tokens;
parser->curtoken = 0;
+ parser->cursize = NULL;
for (i = 0; i < parser->num_tokens; i++) {
jsmn_fill_token(&parser->tokens[i], JSMN_PRIMITIVE, -1, -1);
@@ -132,7 +134,7 @@ static int jsmn_parse_string(jsmn_parser *parser) {
*/
jsmnerr_t jsmn_parse(jsmn_parser *parser) {
int r;
- unsigned int i;
+ int i;
const char *js;
jsmntype_t type;
jsmntok_t *token;
@@ -147,8 +149,11 @@ jsmnerr_t jsmn_parse(jsmn_parser *parser) {
token = jsmn_get_token(parser);
if (token == NULL)
return JSMN_ERROR_NOMEM;
+ if (parser->cursize != NULL)
+ (*parser->cursize)++;
token->type = (c == '{' ? JSMN_OBJECT : JSMN_ARRAY);
token->start = parser->pos;
+ parser->cursize = &token->size;
break;
case '}': case ']':
type = (c == '}' ? JSMN_OBJECT : JSMN_ARRAY);
@@ -158,20 +163,32 @@ jsmnerr_t jsmn_parse(jsmn_parser *parser) {
if (token->type != type) {
return JSMN_ERROR_INVAL;
}
+ parser->cursize = NULL;
token->end = parser->pos + 1;
break;
}
}
+ for (; i >= 0; i--) {
+ token = &parser->tokens[i];
+ if (token->start != -1 && token->end == -1) {
+ parser->cursize = &token->size;
+ break;
+ }
+ }
break;
case '-': case '0': case '1' : case '2': case '3' : case '4':
case '5': case '6': case '7' : case '8': case '9':
case 't': case 'f': case 'n' :
r = jsmn_parse_primitive(parser);
if (r < 0) return r;
+ if (parser->cursize != NULL)
+ (*parser->cursize)++;
break;
case '\"':
r = jsmn_parse_string(parser);
if (r < 0) return r;
+ if (parser->cursize != NULL)
+ (*parser->cursize)++;
break;
case '\t' : case '\r' : case '\n' : case ':' : case ',': case ' ':
break;