summaryrefslogtreecommitdiff
path: root/jsmn.c
diff options
context:
space:
mode:
authorSerge A. Zaitsev <devnull@localhost>2012-02-02 13:26:15 +0200
committerSerge A. Zaitsev <devnull@localhost>2012-02-02 13:26:15 +0200
commitf3b41ae30c7627f540ee539aed51bcca06d23a82 (patch)
treeff99bcf77f56f4065518df38ff9a765845c743ca /jsmn.c
parenta983a7606136a3dfd538a9940c5ebf48d200251c (diff)
fixed: superior node size is now an index, not a pointer (safe to realloc)
Diffstat (limited to 'jsmn.c')
-rw-r--r--jsmn.c22
1 files changed, 11 insertions, 11 deletions
diff --git a/jsmn.c b/jsmn.c
index ef53cc0d2..e38a47252 100644
--- a/jsmn.c
+++ b/jsmn.c
@@ -11,7 +11,6 @@ static jsmntok_t *jsmn_alloc_token(jsmn_parser *parser,
for (i = parser->toknext; i < num_tokens; i++) {
if (tokens[i].start == -1 && tokens[i].end == -1) {
parser->toknext = i + 1;
- tokens[i].size = 0;
return &tokens[i];
}
}
@@ -26,6 +25,7 @@ static void jsmn_fill_token(jsmntok_t *token, jsmntype_t type,
token->type = type;
token->start = start;
token->end = end;
+ token->size = 0;
}
/**
@@ -142,11 +142,11 @@ jsmnerr_t jsmn_parse(jsmn_parser *parser, const char *js, jsmntok_t *tokens,
token = jsmn_alloc_token(parser, tokens, num_tokens);
if (token == NULL)
return JSMN_ERROR_NOMEM;
- if (parser->cursize != NULL)
- (*parser->cursize)++;
+ if (parser->toksuper != -1)
+ tokens[parser->toksuper].size++;
token->type = (c == '{' ? JSMN_OBJECT : JSMN_ARRAY);
token->start = parser->pos;
- parser->cursize = &token->size;
+ parser->toksuper = parser->toknext - 1;
break;
case '}': case ']':
type = (c == '}' ? JSMN_OBJECT : JSMN_ARRAY);
@@ -156,7 +156,7 @@ jsmnerr_t jsmn_parse(jsmn_parser *parser, const char *js, jsmntok_t *tokens,
if (token->type != type) {
return JSMN_ERROR_INVAL;
}
- parser->cursize = NULL;
+ parser->toksuper = -1;
token->end = parser->pos + 1;
break;
}
@@ -164,7 +164,7 @@ jsmnerr_t jsmn_parse(jsmn_parser *parser, const char *js, jsmntok_t *tokens,
for (; i >= 0; i--) {
token = &tokens[i];
if (token->start != -1 && token->end == -1) {
- parser->cursize = &token->size;
+ parser->toksuper = i;
break;
}
}
@@ -172,8 +172,8 @@ jsmnerr_t jsmn_parse(jsmn_parser *parser, const char *js, jsmntok_t *tokens,
case '\"':
r = jsmn_parse_string(parser, js, tokens, num_tokens);
if (r < 0) return r;
- if (parser->cursize != NULL)
- (*parser->cursize)++;
+ if (parser->toksuper != -1)
+ tokens[parser->toksuper].size++;
break;
case '\t' : case '\r' : case '\n' : case ':' : case ',': case ' ':
break;
@@ -188,8 +188,8 @@ jsmnerr_t jsmn_parse(jsmn_parser *parser, const char *js, jsmntok_t *tokens,
#endif
r = jsmn_parse_primitive(parser, js, tokens, num_tokens);
if (r < 0) return r;
- if (parser->cursize != NULL)
- (*parser->cursize)++;
+ if (parser->toksuper != -1)
+ tokens[parser->toksuper].size++;
break;
#ifdef JSMN_STRICT
@@ -218,6 +218,6 @@ jsmnerr_t jsmn_parse(jsmn_parser *parser, const char *js, jsmntok_t *tokens,
void jsmn_init(jsmn_parser *parser) {
parser->pos = 0;
parser->toknext = 0;
- parser->cursize = NULL;
+ parser->toksuper = -1;
}