fx/README.md

142 lines
2.7 KiB
Markdown
Raw Permalink Normal View History

2018-01-25 18:31:26 +00:00
<img src="https://user-images.githubusercontent.com/141232/35405308-4b41f446-0238-11e8-86c1-21f407cc8460.png" height="100" alt="fx">
# [![Build Status](https://travis-ci.org/antonmedv/fx.svg?branch=master)](https://travis-ci.org/antonmedv/fx)
2018-01-25 17:30:05 +00:00
Command-line JSON processing tool
## Features
* Don't need to learn new syntax
* Plain JavaScript
* Formatting and highlighting
## Install
```
$ npm install -g fx
```
## Usage
Pipe into `fx` any JSON and anonymous function for reducing it.
```
$ fx [code ...]
```
2018-01-26 02:35:58 +00:00
Pretty print JSON without passing any arguments:
2018-01-25 17:30:05 +00:00
```
$ echo '{"key":"value"}' | fx
{
"key": "value"
}
```
2018-01-26 02:35:58 +00:00
### Anonymous function
Use an anonymous function as reducer which gets JSON and processes it:
2018-01-25 17:30:05 +00:00
```
2018-01-26 02:35:58 +00:00
$ echo '{"foo": [{"bar": "value"}]}' | fx 'x => x.foo[0].bar'
2018-01-25 17:30:05 +00:00
"value"
```
2018-01-26 02:35:58 +00:00
### This Binding
2018-01-25 17:30:05 +00:00
If you don't pass anonymous function `param => ...`, code will be automatically transformed into anonymous function.
And you can get access to JSON by `this` keyword:
```
2018-01-26 02:35:58 +00:00
$ echo '{"foo": [{"bar": "value"}]}' | fx 'this.foo[0].bar'
2018-01-25 17:30:05 +00:00
"value"
```
2018-01-26 02:35:58 +00:00
### Chain
2018-01-25 17:30:05 +00:00
You can pass any number of anonymous functions for reducing JSON:
```
2018-01-26 02:35:58 +00:00
$ echo '{"foo": [{"bar": "value"}]}' | fx 'x => x.foo' 'this[0]' 'this.bar'
2018-01-25 17:30:05 +00:00
"value"
```
2018-01-26 02:35:58 +00:00
### Generator
2018-01-25 17:30:05 +00:00
If passed code contains `yield` keyword, [generator expression](https://github.com/sebmarkbage/ecmascript-generator-expression)
will be used:
```
2018-01-26 02:35:58 +00:00
$ curl ... | fx 'for (let user of this) if (user.login.startsWith("a")) yield user'
2018-01-25 17:30:05 +00:00
```
Access to JSON through `this` keyword:
```
2018-01-26 02:35:58 +00:00
$ echo '["a", "b"]' | fx 'yield* this'
2018-01-25 17:30:05 +00:00
[
"a",
"b"
]
```
```
2018-01-26 02:35:58 +00:00
$ echo '["a", "b"]' | fx 'yield* this; yield "c";'
2018-01-25 17:30:05 +00:00
[
"a",
"b",
"c"
]
```
2018-01-26 02:35:58 +00:00
### Update
2018-01-25 17:30:05 +00:00
You can update existing JSON using spread operator:
```
2018-01-26 02:35:58 +00:00
$ echo '{"count": 0}' | fx '{...this, count: 1}'
2018-01-25 17:30:05 +00:00
{
"count": 1
}
```
2018-01-26 02:35:58 +00:00
### Use npm package
Use any npm package by installing it globally:
```
$ npm install -g lodash
$ cat package.json | fx 'require("lodash").keys(this.dependencies)'
```
2018-01-26 16:06:25 +00:00
### Formatting
If you need something different then JSON (for example arguments for xargs) do not return anything from reducer.
Undefined value printed into stderr by default.
```
echo '[]' | fx 'void 0'
undefined
```
```
echo '[1,2,3]' | fx 'this.forEach(x => console.log(x))' 2>/dev/null | xargs echo
1 2 3
```
2018-01-26 02:35:58 +00:00
### Other examples
2018-01-25 17:54:06 +00:00
Convert object to array:
```
2018-01-26 02:35:58 +00:00
$ cat package.json | fx 'Object.keys(this.dependencies)'
2018-01-25 17:54:06 +00:00
[
"cardinal",
"get-stdin",
"meow"
]
```
2018-01-25 17:30:05 +00:00
## Related
* [jq](https://github.com/stedolan/jq) cli JSON processor on C
* [jsawk](https://github.com/micha/jsawk) like awk, but for JSON
* [json](https://github.com/trentm/json) another JSON manipulating cli library
2018-01-26 15:38:13 +00:00
* [jl](https://github.com/chrisdone/jl) functional sed for JSON on Haskell
2018-01-25 17:30:05 +00:00
## License
MIT