From af120ab348f2e1a5a39dec035ed9dcf84189a64e Mon Sep 17 00:00:00 2001 From: Biswakalyan Bhuyan Date: Mon, 3 Oct 2022 21:42:20 +0530 Subject: dotfiles --- zsh/oh-my-zsh/plugins/jsontools/README.md | 79 +++++++++++++++++++++++++++++++ 1 file changed, 79 insertions(+) create mode 100644 zsh/oh-my-zsh/plugins/jsontools/README.md (limited to 'zsh/oh-my-zsh/plugins/jsontools/README.md') diff --git a/zsh/oh-my-zsh/plugins/jsontools/README.md b/zsh/oh-my-zsh/plugins/jsontools/README.md new file mode 100644 index 0000000..6a27400 --- /dev/null +++ b/zsh/oh-my-zsh/plugins/jsontools/README.md @@ -0,0 +1,79 @@ +# jsontools + +Handy command line tools for dealing with json data. + +To use it, add `jsontools` to the plugins array in your zshrc file: + +```zsh +plugins=(... jsontools) +``` + +## Usage + +Usage is simple... just take your json data and pipe it into the appropriate jsontool: + +- `pp_json`: pretty prints json. +- `is_json`: returns true if valid json; false otherwise. +- `urlencode_json`: returns a url encoded string for the given json. +- `urldecode_json`: returns decoded json for the given url encoded string. + +### Supports NDJSON (Newline Delimited JSON) + +The plugin also supports [NDJSON](http://ndjson.org/) input, which means all functions +have an alternative function that reads and processes the input line by line. These +functions have the same name except using `ndjson` instead of `json`: + +> `pp_ndjson`, `is_ndjson`, `urlencode_ndjson`, `urldecode_ndjson`. + +### Examples + +- **pp_json**: + +```console +# curl json data and pretty print the results +curl https://coderwall.com/bobwilliams.json | pp_json +``` + +- **is_json**: + +```console +# validate if file's content conforms to a valid JSON schema +$ is_json < data.json +true +# shows true / false and returns the proper exit code +$ echo $? +0 +``` + +- **urlencode_json**: + +```console +# json data directly from the command line +$ echo '{"b":2, "a":1}' | urlencode_json +%7B%22b%22:2,%20%22a%22:1%7D +``` + +- **urldecode_json**: + +```console +# url encoded string to decode +$ echo '%7B%22b%22:2,%20%22a%22:1%7D' | urldecode_json +{"b":2, "a":1} +``` + +- **pp_ndjson**: + +```console +# echo two separate json objects and pretty print both +$ echo '{"a": "b"}\n{"c": [1,2,3]}' | pp_ndjson +{ + "a": "b" +} +{ + "c": [ + 1, + 2, + 3 + ] +} +``` -- cgit v1.2.3-59-g8ed1b