mirror of
https://github.com/wader/fq.git
synced 2024-12-27 15:42:07 +03:00
af35b2848d
Feels like what one would expect when doing to_entries on a decode value struct etc, that is get the pairs in same order as decoder wants. Quite sure this used to the case but was change to sorted key order when to_entries was move from bein implemented in jq to be internal for performance reasons. Now internal gojq to_entries has a special case for JQValue objects. Also use new gojq.JQType* constants for type strings and switch binary type to look more like strings. Can still use _exttype to get "binary".
110 lines
2.2 KiB
Plaintext
110 lines
2.2 KiB
Plaintext
$ fq -i -n '"{}" | json'
|
|
json> (.) | ., tovalue, type, length?
|
|
{}
|
|
{}
|
|
"object"
|
|
0
|
|
json> (.)[0] | ., type, length?
|
|
error: expected an array but got: object
|
|
json> (.)[-1000] | ., type, length?
|
|
error: expected an array but got: object
|
|
json> (.)[1000] | ., type, length?
|
|
error: expected an array but got: object
|
|
json> (.)[1:3] | ., type, length?
|
|
error: expected an array but got: object
|
|
json> (.)[0:-1] | ., type, length?
|
|
error: expected an array but got: object
|
|
json> (.)[-1000:2000] | ., type, length?
|
|
error: expected an array but got: object
|
|
json> (.)["test"] | ., type, length?
|
|
null
|
|
"null"
|
|
0
|
|
json> [(.)[]] | type, length?
|
|
"array"
|
|
0
|
|
json> (.) | keys
|
|
[]
|
|
json> (.) | has("a")
|
|
false
|
|
json> (.) | has(0)
|
|
error: cannot check whether object has a key: 0
|
|
json> (.) | type
|
|
"object"
|
|
json> (.) | tonumber
|
|
error: tonumber cannot be applied to: object
|
|
json> (.) | tostring
|
|
"{}"
|
|
json> (.) + ""
|
|
error: cannot add: object ({}) and string ("")
|
|
json> (.) + 1
|
|
error: cannot add: object ({}) and number (1)
|
|
json> (.)._start | ., type, length?
|
|
0
|
|
"number"
|
|
0
|
|
json> (.)._stop | ., type, length?
|
|
16
|
|
"number"
|
|
16
|
|
json> (.)._len | ., type, length?
|
|
16
|
|
"number"
|
|
16
|
|
json> (.)._name | ., type, length?
|
|
""
|
|
"string"
|
|
0
|
|
json> (.)._sym | ., type, length?
|
|
null
|
|
"null"
|
|
0
|
|
json> (.)._description | ., type, length?
|
|
null
|
|
"null"
|
|
0
|
|
json> (.)._path | ., type, length?
|
|
[]
|
|
"array"
|
|
0
|
|
json> (.)._bits | ., type, length?
|
|
|00 01 02 03 04 05 06 07 08 09 0a 0b 0c 0d 0e 0f|0123456789abcdef|
|
|
0x0|7b 7d| |{}| |.: raw bits 0x0-0x1.7 (2)
|
|
"string"
|
|
16
|
|
json>
|
|
json> (.)._bytes | ., type, length?
|
|
|00 01 02 03 04 05 06 07 08 09 0a 0b 0c 0d 0e 0f|0123456789abcdef|
|
|
0x0|7b 7d| |{}| |.: raw bits 0x0-0x1.7 (2)
|
|
"string"
|
|
2
|
|
json>
|
|
json> (.)._error | ., type, length?
|
|
null
|
|
"null"
|
|
0
|
|
json> (.)._unknown | ., type, length?
|
|
false
|
|
"boolean"
|
|
json> (.).a = 1
|
|
{
|
|
"a": 1
|
|
}
|
|
json> (.)[0] = 1
|
|
error: expected an array but got: object
|
|
json> (.).a |= empty
|
|
{}
|
|
json> (.)[0] |= empty
|
|
error: expected an array but got: object
|
|
json> (.) | setpath(["a"]; 1)
|
|
{
|
|
"a": 1
|
|
}
|
|
json> (.) | setpath([0]; 1)
|
|
error: expected an array but got: object ({})
|
|
json> (.) | delpaths([["a"]])
|
|
{}
|
|
json> (.) | delpaths([[0]])
|
|
error: expected an array but got: object ({})
|
|
json> ^D
|