diff options
author | Nicolas "Pixel" Noble <pixel@nobis-crew.org> | 2016-03-30 07:01:52 +0200 |
---|---|---|
committer | Nicolas "Pixel" Noble <pixel@nobis-crew.org> | 2016-03-30 07:03:09 +0200 |
commit | 82a91c91d01ce9b999c8821ed13515883468e203 (patch) | |
tree | 0afa850238aa4ca8406c61ad3d7a62973d972f6d /src/core/lib/json | |
parent | fdbebb9049649d78b5d834def96715e81c8797e6 (diff) |
Fixing json memory leak.
Diffstat (limited to 'src/core/lib/json')
-rw-r--r-- | src/core/lib/json/json_reader.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/src/core/lib/json/json_reader.c b/src/core/lib/json/json_reader.c index 4cff13dff1..098e089eed 100644 --- a/src/core/lib/json/json_reader.c +++ b/src/core/lib/json/json_reader.c @@ -180,6 +180,13 @@ grpc_json_reader_status grpc_json_reader_run(grpc_json_reader *reader) { case GRPC_JSON_STATE_VALUE_NUMBER_WITH_DECIMAL: case GRPC_JSON_STATE_VALUE_NUMBER_ZERO: case GRPC_JSON_STATE_VALUE_NUMBER_EPM: + if (reader->depth == 0) { + return GRPC_JSON_PARSE_ERROR; + } else if ((c == '}') && !reader->in_object) { + return GRPC_JSON_PARSE_ERROR; + } else if ((c == ']') && !reader->in_array) { + return GRPC_JSON_PARSE_ERROR; + } success = (uint32_t)json_reader_set_number(reader); if (!success) return GRPC_JSON_PARSE_ERROR; json_reader_string_clear(reader); |