2
0
mirror of https://github.com/bpkg/bpkg synced 2024-11-17 21:26:01 +00:00
bpkg/lib/json/README.md
Ben Peachey 1107d7608c Changes various (text) files to *not* be executable
This change affects LICENSE, README.md, package.json and Makefile files.
2018-02-02 11:16:54 -05:00

70 lines
1.7 KiB
Markdown

# JSON.sh
yo, so it's a json parser written in bash
pipe json to it, and it traverses the json objects and prints out the
path to the current object (as a JSON array) and then the object, without whitespace.
``` bash
$ json_parse < package.json
["name"] "JSON.sh"
["version"] "0.0.0"
["description"] ""
["homepage"] "http://github.com/dominictarr/JSON.sh"
["repository","type"] "git"
["repository","url"] "https://github.com/dominictarr/JSON.sh.git"
["repository"] {"type":"git","url":"https://github.com/dominictarr/JSON.sh.git"}
["bin","json_parse"] "./JSON.sh"
["bin"] {"json_parse":"./JSON.sh"}
["dependencies"] {}
# ... etc
```
a more complex example:
``` bash
curl registry.npmjs.org/express | ./JSON.sh | egrep '\["versions","[^"]*"\]'
... try it and see
```
## Options
-b
> Brief output. Combines 'Leaf only' and 'Prune empty' options.
-l
> Leaf only. Only show leaf nodes, which stops data duplication.
-p
> Prune empty. Exclude fields with empty values.
-h
> Show help text.
## Cool Links
* [step-/JSON.awk](https://github.com/step-/JSON.awk) JSON.sh ported to awk
* [kristopolous/TickTick](https://github.com/kristopolous/TickTick) Object Oriented BASH
* [archan937/jsonv.sh](https://github.com/archan937/jsonv.sh)
## Examples
If you have any examples with JSON.sh, streaming twitter, github, or whatever!
please issue a pull request and i will include them.
## Installation
install via npm or from AUR on archlinux
* `npm install -g JSON.sh`
* `yaourt -Sy json-sh`
([json-sh on aur](https://aur.archlinux.org/packages/json-sh/)
thanks to [kremlin-](https://github.com/kremlin-))
## License
This software is available under the following licenses:
* MIT
* Apache 2