2012-09-18 23:40:19 +01:00
|
|
|
jq
|
|
|
|
==
|
|
|
|
|
|
|
|
jq is a command-line JSON processor.
|
|
|
|
|
|
|
|
If you want to learn to use jq, read the documentation at
|
2015-02-15 18:08:09 -06:00
|
|
|
[http://stedolan.github.io/jq](http://stedolan.github.io/jq). This
|
2012-09-18 23:40:19 +01:00
|
|
|
documentation is generated from the docs/ folder of this repository.
|
2014-06-12 18:17:39 -07:00
|
|
|
You can also try it online at [jqplay.org](http://jqplay.org).
|
2012-09-18 23:40:19 +01:00
|
|
|
|
|
|
|
If you want to hack on jq, feel free, but be warned that its internals
|
2013-05-11 15:15:56 +01:00
|
|
|
are not well-documented at the moment. Bring a hard hat and a
|
2015-02-15 18:08:09 -06:00
|
|
|
shovel. Also, read the wiki: http://github.com/stedolan/jq/wiki
|
2012-09-18 23:40:19 +01:00
|
|
|
|
2015-02-15 17:57:53 -06:00
|
|
|
Source tarball and built executable releases can be found on the
|
|
|
|
homepage and on the github release page, https://github.com/stedolan/jq/releases
|
|
|
|
|
2014-11-11 23:02:31 +00:00
|
|
|
If you're building directly from the latest git, you'll need flex,
|
2015-02-15 17:57:53 -06:00
|
|
|
bison (3.0 or newer), libtool, make, and autoconf installed. To get
|
|
|
|
regexp support you'll also need to install Oniguruma (note that jq's
|
|
|
|
tests require regexp support to pass). To build, run:
|
2013-05-11 15:15:56 +01:00
|
|
|
|
2015-01-01 16:26:55 -06:00
|
|
|
autoreconf -i # if building from git
|
2013-05-11 15:15:56 +01:00
|
|
|
./configure
|
2014-06-04 18:29:30 -05:00
|
|
|
make -j8
|
|
|
|
make check
|
2013-05-11 15:15:56 +01:00
|
|
|
|
2015-02-15 17:57:53 -06:00
|
|
|
To build without bison or flex, add `--disable-maintainer-mode` to the
|
|
|
|
./configure invocation:
|
|
|
|
|
|
|
|
./configure --disable-maintainer-mode
|
|
|
|
|
|
|
|
(Developers must not use `--disable-maintainer-mode`, not when making
|
|
|
|
changes to the jq parser and/or lexer.)
|
|
|
|
|
2015-01-01 16:26:55 -06:00
|
|
|
To build a statically linked version of jq, run:
|
|
|
|
|
|
|
|
make LDFLAGS=-all-static
|
|
|
|
|
2015-02-15 18:08:09 -06:00
|
|
|
After make finishes, you'll be able to use `./jq`. You can also
|
2013-06-18 00:28:50 +01:00
|
|
|
install it using:
|
2013-05-11 15:15:56 +01:00
|
|
|
|
2013-06-18 00:28:50 +01:00
|
|
|
sudo make install
|
|
|
|
|
|
|
|
If you're not using the latest git version but instead building a
|
|
|
|
released tarball (available on the website), then you won't need to
|
|
|
|
run `autoreconf` (and shouldn't), and you won't need flex or bison.
|
2014-06-04 18:29:30 -05:00
|
|
|
|
|
|
|
To cross-compile for OS X and Windows, see docs/Rakefile's build task
|
|
|
|
and scripts/crosscompile. You'll need a cross-compilation environment,
|
|
|
|
such as Mingw for cross-compiling for Windows.
|
|
|
|
|
2015-01-01 16:26:55 -06:00
|
|
|
Cross-compilation requires a clean workspace, then:
|
|
|
|
|
|
|
|
# git clean ...
|
|
|
|
autoreconf -i
|
|
|
|
./configure
|
|
|
|
make distclean
|
|
|
|
scripts/crosscompile <name-of-build> <configure-options>
|
|
|
|
|
|
|
|
Use the --host= and --target= ./configure options to select a
|
2015-02-15 18:08:09 -06:00
|
|
|
cross-compilation environment. See also the wiki.
|