summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEmanuele Torre <torreemanuele6@gmail.com>2023-07-16 11:56:36 +0200
committerNico Williams <nico@cryptonector.com>2023-07-17 13:15:55 -0500
commit4b3090a9abba3fa5b94a46c5f44944deec17d5d4 (patch)
tree17cdd463eb33929d816a45744f2152a72bc785cd
parente79335e3a587d77954face2137fc3d4b5482129e (diff)
Make stream parser error when a non-empty object or array is used as key
Fixes #2463
-rw-r--r--src/jv_parse.c22
-rwxr-xr-xtests/shtest10
2 files changed, 32 insertions, 0 deletions
diff --git a/src/jv_parse.c b/src/jv_parse.c
index 2caf330b..3a8718ae 100644
--- a/src/jv_parse.c
+++ b/src/jv_parse.c
@@ -246,6 +246,17 @@ static pfunc stream_token(struct jv_parser* p, char ch) {
case '[':
if (jv_is_valid(p->next))
return "Expected a separator between values";
+ if (p->last_seen == JV_LAST_OPEN_OBJECT)
+ // Looks like {["foo"]}
+ return "Expected string key after '{', not '['";
+ if (p->last_seen == JV_LAST_COMMA) {
+ last = jv_array_get(jv_copy(p->path), p->stacklen - 1);
+ k = jv_get_kind(last);
+ jv_free(last);
+ if (k != JV_KIND_NUMBER)
+ // Looks like {"x":"y",["foo"]}
+ return "Expected string key after ',' in object, not '['";
+ }
p->path = jv_array_append(p->path, jv_number(0)); // push
p->last_seen = JV_LAST_OPEN_ARRAY;
p->stacklen++;
@@ -254,6 +265,17 @@ static pfunc stream_token(struct jv_parser* p, char ch) {
case '{':
if (p->last_seen == JV_LAST_VALUE)
return "Expected a separator between values";
+ if (p->last_seen == JV_LAST_OPEN_OBJECT)
+ // Looks like {{"foo":"bar"}}
+ return "Expected string key after '{', not '{'";
+ if (p->last_seen == JV_LAST_COMMA) {
+ last = jv_array_get(jv_copy(p->path), p->stacklen - 1);
+ k = jv_get_kind(last);
+ jv_free(last);
+ if (k != JV_KIND_NUMBER)
+ // Looks like {"x":"y",{"foo":"bar"}}
+ return "Expected string key after ',' in object, not '{'";
+ }
// Push object key: null, since we don't know it yet
p->path = jv_array_append(p->path, jv_null()); // push
p->last_seen = JV_LAST_OPEN_OBJECT;
diff --git a/tests/shtest b/tests/shtest
index 8af791ae..a7fba445 100755
--- a/tests/shtest
+++ b/tests/shtest
@@ -222,6 +222,16 @@ fi
echo '{"a":1,"b",' | $JQ --stream > /dev/null 2> $d/err || true
grep 'Objects must consist of key:value pairs' $d/err > /dev/null
+## Regression tests for issue #2463 assert when stream parse non-scalar object key
+echo '{{"a":"b"}}' | $JQ --stream > /dev/null 2> $d/err || true
+grep "Expected string key after '{', not '{'" $d/err > /dev/null
+echo '{"x":"y",{"a":"b"}}' | $JQ --stream > /dev/null 2> $d/err || true
+grep "Expected string key after ',' in object, not '{'" $d/err > /dev/null
+echo '{["a","b"]}' | $JQ --stream > /dev/null 2> $d/err || true
+grep "Expected string key after '{', not '\\['" $d/err > /dev/null
+echo '{"x":"y",["a","b"]}' | $JQ --stream > /dev/null 2> $d/err || true
+grep "Expected string key after ',' in object, not '\\['" $d/err > /dev/null
+
## Regression test for issue #2572 assert when using --jsonargs and invalid JSON
$JQ -n --jsonargs null invalid && EC=$? || EC=$?
if [ "$EC" -ne 2 ]; then