mirror of
https://github.com/SquidDev-CC/CC-Tweaked
synced 2024-12-15 04:30:29 +00:00
Added parse_empty_array to textutils.unserialiseJSON (#1092)
Fixes #1089.
This commit is contained in:
parent
78334c4cb1
commit
d9e75d7c47
@ -631,7 +631,13 @@ do
|
|||||||
end
|
end
|
||||||
|
|
||||||
if c == "" then return expected(pos, c, "']'") end
|
if c == "" then return expected(pos, c, "']'") end
|
||||||
if c == "]" then return empty_json_array, pos + 1 end
|
if c == "]" then
|
||||||
|
if opts.parse_empty_array ~= false then
|
||||||
|
return empty_json_array, pos + 1
|
||||||
|
else
|
||||||
|
return {}, pos + 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
while true do
|
while true do
|
||||||
n, arr[n], pos = n + 1, decode_impl(str, pos, opts)
|
n, arr[n], pos = n + 1, decode_impl(str, pos, opts)
|
||||||
@ -652,37 +658,51 @@ do
|
|||||||
error_at(pos, "Unexpected character %q.", c)
|
error_at(pos, "Unexpected character %q.", c)
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Converts a serialised JSON string back into a reassembled Lua object.
|
--[[- Converts a serialised JSON string back into a reassembled Lua object.
|
||||||
--
|
|
||||||
-- This may be used with @{textutils.serializeJSON}, or when communicating
|
This may be used with @{textutils.serializeJSON}, or when communicating
|
||||||
-- with command blocks or web APIs.
|
with command blocks or web APIs.
|
||||||
--
|
|
||||||
-- If a `null` value is encountered, it is converted into @{textutils.json_null}.
|
If a `null` value is encountered, it is converted into `nil`. It can be converted
|
||||||
-- If an empty array is encountered, it is converted into @{textutils.empty_json_array}.
|
into @{textutils.json_null} with the `parse_null` option.
|
||||||
--
|
|
||||||
-- @tparam string s The serialised string to deserialise.
|
If an empty array is encountered, it is converted into @{textutils.empty_json_array}.
|
||||||
-- @tparam[opt] { nbt_style? = boolean, parse_null? = boolean } options
|
It can be converted into a new empty table with the `parse_empty_array` option.
|
||||||
-- Options which control how this JSON object is parsed.
|
|
||||||
--
|
@tparam string s The serialised string to deserialise.
|
||||||
-- - `nbt_style`: When true, this will accept [stringified NBT][nbt] strings,
|
@tparam[opt] { nbt_style? = boolean, parse_null? = boolean, parse_empty_array? = boolean } options
|
||||||
-- as produced by many commands.
|
Options which control how this JSON object is parsed.
|
||||||
-- - `parse_null`: When true, `null` will be parsed as @{json_null}, rather
|
|
||||||
-- than `nil`.
|
- `nbt_style`: When true, this will accept [stringified NBT][nbt] strings,
|
||||||
--
|
as produced by many commands.
|
||||||
-- [nbt]: https://minecraft.gamepedia.com/NBT_format
|
- `parse_null`: When true, `null` will be parsed as @{json_null}, rather than
|
||||||
-- @return[1] The deserialised object
|
`nil`.
|
||||||
-- @treturn[2] nil If the object could not be deserialised.
|
- `parse_empty_array`: When false, empty arrays will be parsed as a new table.
|
||||||
-- @treturn string A message describing why the JSON string is invalid.
|
By default (or when this value is true), they are parsed as @{empty_json_array}.
|
||||||
-- @since 1.87.0
|
|
||||||
-- @see textutils.json_null Use to serialize a JSON `null` value.
|
[nbt]: https://minecraft.gamepedia.com/NBT_format
|
||||||
-- @see textutils.empty_json_array Use to serialize a JSON empty array.
|
@return[1] The deserialised object
|
||||||
|
@treturn[2] nil If the object could not be deserialised.
|
||||||
|
@treturn string A message describing why the JSON string is invalid.
|
||||||
|
@since 1.87.0
|
||||||
|
@see textutils.json_null Use to serialize a JSON `null` value.
|
||||||
|
@see textutils.empty_json_array Use to serialize a JSON empty array.
|
||||||
|
@usage Unserialise a basic JSON object
|
||||||
|
|
||||||
|
textutils.unserialiseJSON('{"name": "Steve", "age": null}')
|
||||||
|
|
||||||
|
@usage Unserialise a basic JSON object, returning null values as @{json_null}.
|
||||||
|
|
||||||
|
textutils.unserialiseJSON('{"name": "Steve", "age": null}', { parse_null = true })
|
||||||
|
]]
|
||||||
unserialise_json = function(s, options)
|
unserialise_json = function(s, options)
|
||||||
expect(1, s, "string")
|
expect(1, s, "string")
|
||||||
expect(2, options, "table", "nil")
|
expect(2, options, "table", "nil")
|
||||||
|
|
||||||
if options then
|
if options then
|
||||||
field(options, "nbt_style", "boolean", "nil")
|
field(options, "nbt_style", "boolean", "nil")
|
||||||
field(options, "nbt_style", "boolean", "nil")
|
field(options, "parse_null", "boolean", "nil")
|
||||||
|
field(options, "parse_empty_array", "boolean", "nil")
|
||||||
else
|
else
|
||||||
options = {}
|
options = {}
|
||||||
end
|
end
|
||||||
|
@ -177,8 +177,15 @@ describe("The textutils library", function()
|
|||||||
expect(textutils.unserializeJSON("null", { parse_null = false })):eq(nil)
|
expect(textutils.unserializeJSON("null", { parse_null = false })):eq(nil)
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it("an empty array", function()
|
it("an empty array when parse_empty_array is true", function()
|
||||||
expect(textutils.unserializeJSON("[]", { parse_null = false })):eq(textutils.empty_json_array)
|
expect(textutils.unserializeJSON("[]")):eq(textutils.empty_json_array)
|
||||||
|
expect(textutils.unserializeJSON("[]", { parse_empty_array = true })):eq(textutils.empty_json_array)
|
||||||
|
end)
|
||||||
|
|
||||||
|
it("an empty array when parse_empty_array is false", function()
|
||||||
|
expect(textutils.unserializeJSON("[]", { parse_empty_array = false }))
|
||||||
|
:ne(textutils.empty_json_array)
|
||||||
|
:same({})
|
||||||
end)
|
end)
|
||||||
|
|
||||||
it("basic objects", function()
|
it("basic objects", function()
|
||||||
|
Loading…
Reference in New Issue
Block a user