10 releases

0.2.1 Nov 2, 2024
0.2.0 Nov 2, 2024
0.1.7 Nov 2, 2024
0.1.6 Feb 1, 2023
0.1.5 Dec 31, 2022

#302 in Filesystem

MIT license

16KB
275 lines

Recast

Transforms one serialization format into another. Available serialization formats include:

  • JSON (application/json)
  • TOML (application/toml)
  • Yaml (text/x-yaml)
  • CSV (text/csv)
  • XML (text/xml)
  • Query strings
  • Msgpack

Installation

Package manager Command
Cargo cargo install recast

The releases page contains pre-compiled releases and shell completion files

Usage

Transforms one serialization format into another

Usage: recast [OPTIONS] [FILE]

Arguments:
  [FILE]  Input from file

Options:
  -f, --from <FORMAT>  Input format [possible values: json, toml, yaml, query, csv, xml, msgpack]
  -t, --to <FORMAT>    Output format [possible values: json, toml, yaml, query, csv, xml, msgpack]
  -o, --out <FILE>     Output to file
  -h, --help           Print help (see more with '--help')
  -V, --version        Print version

Examples

jq

Leverage jq's powerful filters on other serialization formats

$ recast -f toml -t json Cargo.lock \
  | jq '.package | map({name: .name, version: .version}) | sort_by(.name)' \
  | recast -f json -t csv \
  | head -n 5
name,version
addr2line,0.19.0
adler,1.0.2
autocfg,1.1.0
backtrace,0.3.67

Syntax highlighting

recast doesn't provide syntax highlighting, but you can leverage other cli tools like bat for this purpose

recast -t json Cargo.toml | bat --language json

Dependencies

~9–16MB
~200K SLoC