mirror of
https://github.com/SquidDev-CC/CC-Tweaked
synced 2025-01-10 01:10:30 +00:00
Clarify some quicks of JSON serialisation
There's a mismatch between how Lua and JSON's values are defined, which means that serialisation is a little confusing at times. This commit attempts to document them a little better. Closes #1885, closes #1920
This commit is contained in:
parent
bfb28b4710
commit
be59f1a875
@ -851,13 +851,32 @@ unserialise = unserialize -- GB version
|
|||||||
|
|
||||||
--[[- Returns a JSON representation of the given data.
|
--[[- Returns a JSON representation of the given data.
|
||||||
|
|
||||||
This function attempts to guess whether a table is a JSON array or
|
|
||||||
object. However, empty tables are assumed to be empty objects - use
|
|
||||||
[`textutils.empty_json_array`] to mark an empty array.
|
|
||||||
|
|
||||||
This is largely intended for interacting with various functions from the
|
This is largely intended for interacting with various functions from the
|
||||||
[`commands`] API, though may also be used in making [`http`] requests.
|
[`commands`] API, though may also be used in making [`http`] requests.
|
||||||
|
|
||||||
|
Lua has a rather different data model to Javascript/JSON. As a result, some Lua
|
||||||
|
values do not serialise cleanly into JSON.
|
||||||
|
|
||||||
|
- Lua tables can contain arbitrary key-value pairs, but JSON only accepts arrays,
|
||||||
|
and objects (which require a string key). When serialising a table, if it only
|
||||||
|
has numeric keys, then it will be treated as an array. Otherwise, the table will
|
||||||
|
be serialised to an object using the string keys. Non-string keys (such as numbers
|
||||||
|
or tables) will be dropped.
|
||||||
|
|
||||||
|
A consequence of this is that an empty table will always be serialised to an object,
|
||||||
|
not an array. [`textutils.empty_json_array`] may be used to express an empty array.
|
||||||
|
|
||||||
|
- Lua strings are an a sequence of raw bytes, and do not have any specific encoding.
|
||||||
|
However, JSON strings must be valid unicode. By default, non-ASCII characters in a
|
||||||
|
string are serialised to their unicode code point (for instance, `"\xfe"` is
|
||||||
|
converted to `"\u00fe"`). The `unicode_strings` option may be set to treat all input
|
||||||
|
strings as UTF-8.
|
||||||
|
|
||||||
|
- Lua does not distinguish between missing keys (`undefined` in JS) and ones explicitly
|
||||||
|
set to `null`. As a result `{ x = nil }` is serialised to `{}`. [`textutils.json_null`]
|
||||||
|
may be used to get an explicit null value (`{ x = textutils.json_null }` will serialise
|
||||||
|
to `{"x": null}`).
|
||||||
|
|
||||||
@param[1] t The value to serialise. Like [`textutils.serialise`], this should not
|
@param[1] t The value to serialise. Like [`textutils.serialise`], this should not
|
||||||
contain recursive tables or functions.
|
contain recursive tables or functions.
|
||||||
@tparam[1,opt] {
|
@tparam[1,opt] {
|
||||||
|
Loading…
Reference in New Issue
Block a user