forked from Dependencies/lua-json
Added checking and tests for trailing garbage when decoding
parent
19cc024df6
commit
eb6e343c53
7
json.lua
7
json.lua
|
@ -388,7 +388,12 @@ function json.decode(str)
|
||||||
if type(str) ~= "string" then
|
if type(str) ~= "string" then
|
||||||
error("expected argument of type string, got " .. type(str))
|
error("expected argument of type string, got " .. type(str))
|
||||||
end
|
end
|
||||||
return ( parse(str, next_char(str, 1, space_chars, true)) )
|
local res, idx = parse(str, next_char(str, 1, space_chars, true))
|
||||||
|
idx = next_char(str, idx, space_chars, true)
|
||||||
|
if idx <= #str then
|
||||||
|
decode_error(str, idx, "trailing garbage")
|
||||||
|
end
|
||||||
|
return res
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -125,6 +125,8 @@ test("decode invalid", function()
|
||||||
'{]',
|
'{]',
|
||||||
'[}',
|
'[}',
|
||||||
'"a',
|
'"a',
|
||||||
|
'10 xx',
|
||||||
|
'{}123'
|
||||||
}
|
}
|
||||||
for i, v in ipairs(t) do
|
for i, v in ipairs(t) do
|
||||||
local status = pcall(json.decode, v)
|
local status = pcall(json.decode, v)
|
||||||
|
@ -234,5 +236,3 @@ test("encode escape", function()
|
||||||
assert( res == v, fmt("'%s' was not escaped properly", k) )
|
assert( res == v, fmt("'%s' was not escaped properly", k) )
|
||||||
end
|
end
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue