-
Notifications
You must be signed in to change notification settings - Fork 1.6k
Regarding gojq
The Go implementation of jq, gojq, follows the jq language specification very closely and offers some features, such as support for YAML and for unbounded-precision integer arithmetic, which jq users might wish to take advantage of. This short article attempts to highlight such features as well as some limitations and drawbacks of gojq that jq users will probably want to be aware of.
The main points of comparison are:
jq-1.6 jqMaster (the "master" version as of around Jan 1, 2020) gojq-0.12.4 gojq (as of around July 27, 2021)
- Functional
- gojq supports infinite-precision integer arithmetic.
Note, however, that there was a bug in gojq-0.12.4 that caused integer/integer division to revert to floating-point arithmetic; this bug has subsequently been fixed.
-
jqMaster retains the precision of all numeric literals, but gojq only retains the precision of integer literals.
-
gojq always sorts the keys of JSON objects and has no 'keys_unsorted' function.
-
jq's handling of "$-variables" in function definition headers is incorrect, and indeed gojq-0.12.4 implemented the intended semantics; this however introduced an unwanted discrepancy between jq and gojq, and as of this writing, gojq now mimics jq's faulty handling of these "$-variables".
-
gojq supports YAML, both as input and as output.
-
Some documented jq filters are missing from gojq:
keys_unsorted
$__loc__
input_filename
input_line_number
-
The gojq parser and interpreter can easily be incorporated into a Go project.
-
jq-1.6 does not support optional
else
but jqMaster and gojq does.
Please see the gojq README for a more comprehensive description of the functional differences.
- Performance
Memory management is perhaps gojq's weakest point. For what might be called small or light tasks, gojq is sometimes slightly faster than jq, but generally requires more memory, and often much more memory, to the point of memory exhaustion, which typically results in a somewhat bland failure message. For computationally intensive tasks, gojq is generally slower and often much slower than jq.
Note that TCO (tail-call optimization) in recent versions of gojq is superior to that in gojq-0.12.4.
- Bug fixes and support
Currently, gojq is being maintained more actively than jq, and several important bugs in jq (e.g. related to timezones) have been fixed in gojq. These are summarized in the gojq README.
- Home
- FAQ
- jq Language Description
- Cookbook
- Modules
- Parsing Expression Grammars
- Docs for Oniguruma Regular Expressions (RE.txt)
- Advanced Topics
- Guide for Contributors
- How To
- C API
- jq Internals
- Tips
- Development