1
1
mirror of https://github.com/wader/fq.git synced 2024-12-26 15:02:28 +03:00
fq/pkg/interp/testdata/value_number.fqtest
Mattias Wadman 518f6af4a8 gojq: Rebase fq fork
Upstream changes:
Many performance improvements
Error message improvments
Lots of refactoring

Most of the JQValue interface changes in gojq fork had to be reworked but
resultet in a much nicer and cleaner changeset.

fq changes:
Assignment to JQValue (like a decode value) now shallowly converts the value into
a jq value before assigning. Was a bit hacky as it was and this makes JQValue
behave more like real jq values. This also fixes some advanced indexing issues.

Actual custom path updates will be something for the future.
2022-04-11 19:23:15 +02:00

108 lines
3.1 KiB
Plaintext

$ fq -i -d mp3 . /test.mp3
mp3> .headers[0].version | ., tovalue, type, length?
|00 01 02 03 04 05 06 07 08 09 0a 0b 0c 0d 0e 0f|0123456789abcdef|
0x0| 04 | . |.headers[0].version: 4
4
"number"
4
mp3> .headers[0].version[0] | ., type, length?
error: expected an array but got: number
mp3> .headers[0].version[-1000] | ., type, length?
error: expected an array but got: number
mp3> .headers[0].version[1000] | ., type, length?
error: expected an array but got: number
mp3> .headers[0].version[1:3] | ., type, length?
error: expected an array but got: number
mp3> .headers[0].version[0:-1] | ., type, length?
error: expected an array but got: number
mp3> .headers[0].version[-1000:2000] | ., type, length?
error: expected an array but got: number
mp3> .headers[0].version["test"] | ., type, length?
error: expected an object but got: number
mp3> [.headers[0].version[]] | type, length?
error: cannot iterate over: number
mp3> .headers[0].version | keys
error: keys cannot be applied to: number
mp3> .headers[0].version | has("a")
error: has cannot be applied to: number
mp3> .headers[0].version | has(0)
error: has cannot be applied to: number
mp3> .headers[0].version | type
"number"
mp3> .headers[0].version | tonumber
4
mp3> .headers[0].version | tostring
"4"
mp3> .headers[0].version + ""
error: cannot add: number (4) and string ("")
mp3> .headers[0].version + 1
5
mp3> .headers[0].version._start | ., type, length?
24
"number"
24
mp3> .headers[0].version._stop | ., type, length?
32
"number"
32
mp3> .headers[0].version._len | ., type, length?
8
"number"
8
mp3> .headers[0].version._name | ., type, length?
"version"
"string"
7
mp3> .headers[0].version._sym | ., type, length?
null
"null"
0
mp3> .headers[0].version._description | ., type, length?
null
"null"
0
mp3> .headers[0].version._path | ., type, length?
[
"headers",
0,
"version"
]
"array"
3
mp3> .headers[0].version._bits | ., type, length?
|00 01 02 03 04 05 06 07 08 09 0a 0b 0c 0d 0e 0f|0123456789abcdef|
0x0| 04 | . |.: raw bits 0x3-0x3.7 (1)
"binary"
8
mp3>
mp3> .headers[0].version._bytes | ., type, length?
|00 01 02 03 04 05 06 07 08 09 0a 0b 0c 0d 0e 0f|0123456789abcdef|
0x0| 04 | . |.: raw bits 0x3-0x3.7 (1)
"binary"
1
mp3>
mp3> .headers[0].version._error | ., type, length?
null
"null"
0
mp3> .headers[0].version._unknown | ., type, length?
false
"boolean"
mp3> .headers[0].version.a = 1
error: expected an object but got: number (4)
mp3> .headers[0].version[0] = 1
error: expected an array but got: number (4)
mp3> .headers[0].version.a |= empty
error: expected an object but got: number
mp3> .headers[0].version[0] |= empty
error: expected an array but got: number
mp3> .headers[0].version | setpath(["a"]; 1)
error: expected an object but got: number (4)
mp3> .headers[0].version | setpath([0]; 1)
error: expected an array but got: number (4)
mp3> .headers[0].version | delpaths([["a"]])
error: expected an object but got: number (4)
mp3> .headers[0].version | delpaths([[0]])
error: expected an array but got: number (4)
mp3> ^D