A simple tool to deserialize data from an input encoding, transform it and serialize it back into an output encoding.
Uses jq
for data transformation and
requires rust >= 1.56.0.
Check out the releases page
for prebuilt versions of dts
.
sh
cargo install dts
Clone the repository and run:
sh
cargo install --locked --path .
sh
dts [<source>...] [-j <jq-expression>] [-O <sink>...]
For a full list of available flags consult the help:
sh
dts --help
Convert YAML to TOML:
sh
dts input.yaml -o toml
Load all YAML files from sub directories and merge them into one:
sh
dts . --glob '**/*.yaml' output.yaml
Transform the input data using a jq
expression:
sh
dts tests/fixtures/example.json -j '.users | map(select(.age < 30))'
Use jq
filter expression from a file:
sh
dts tests/fixtures/example.json -j @my-filter.jq
Read data from stdin:
sh
echo '{"foo": {"bar": "baz"}}' | dts -i json -o yaml
dts
supports output coloring and syntax highlighting. The coloring behaviour
can be controlled via the --color
flag or DTS_COLOR
environment variable.
If the default theme used for syntax highlighting does not suit you, you can
change it via the --theme
flag or DTS_THEME
environment variable.
Available themes can be listed via:
sh
dts --list-themes
Hint: The color
feature can be disabled at compile time if you don't want
to have colors at all. See the Cargo feature section below.
Right now dts
supports the following encodings:
Support for colored output is provided by the color
feature which is enabled
by default. The feature increases binary size and may be disabled via:
sh
cargo build --no-default-features --release
If you just want to disable colors by default with the option to enable them
conditionally, you can also set the NO_COLOR
environment variable or set DTS_COLOR=never
.
The source code of dts is released under the MIT License. See the bundled LICENSE file for details.