json_add_tok: simplify, don't try to canonicalize.
I'm not sure why we were turning strings into bools, etc. Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
This commit is contained in:
parent
165d039f6c
commit
976c6e5c83
|
@ -830,44 +830,11 @@ void json_add_time(struct json_stream *result, const char *fieldname,
|
|||
void json_add_tok(struct json_stream *result, const char *fieldname,
|
||||
const jsmntok_t *tok, const char *buffer)
|
||||
{
|
||||
int i = 0;
|
||||
const jsmntok_t *t;
|
||||
char *space;
|
||||
assert(tok->type != JSMN_UNDEFINED);
|
||||
|
||||
switch (tok->type) {
|
||||
case JSMN_PRIMITIVE:
|
||||
if (json_tok_is_num(buffer, tok)) {
|
||||
json_to_int(buffer, tok, &i);
|
||||
json_add_num(result, fieldname, i);
|
||||
}
|
||||
return;
|
||||
|
||||
case JSMN_STRING:
|
||||
if (json_tok_streq(buffer, tok, "true"))
|
||||
json_add_bool(result, fieldname, true);
|
||||
else if (json_tok_streq(buffer, tok, "false"))
|
||||
json_add_bool(result, fieldname, false);
|
||||
else
|
||||
json_add_string(result, fieldname, json_strdup(tmpctx, buffer, tok));
|
||||
return;
|
||||
|
||||
case JSMN_ARRAY:
|
||||
json_array_start(result, fieldname);
|
||||
json_for_each_arr(i, t, tok)
|
||||
json_add_tok(result, NULL, t, buffer);
|
||||
json_array_end(result);
|
||||
return;
|
||||
|
||||
case JSMN_OBJECT:
|
||||
json_object_start(result, fieldname);
|
||||
json_for_each_obj(i, t, tok)
|
||||
json_add_tok(result, json_strdup(tmpctx, buffer, t), t+1, buffer);
|
||||
json_object_end(result);
|
||||
return;
|
||||
|
||||
case JSMN_UNDEFINED:
|
||||
break;
|
||||
}
|
||||
abort();
|
||||
space = json_member_direct(result, fieldname, json_tok_full_len(tok));
|
||||
memcpy(space, json_tok_full(buffer, tok), json_tok_full_len(tok));
|
||||
}
|
||||
|
||||
void json_add_errcode(struct json_stream *result, const char *fieldname,
|
||||
|
|
Loading…
Reference in New Issue