jq-front
is a simple tool to give your JSON files a power of inheritance and templating.
In testing, system configuration, gaming, music compositions, etc., we see a lot of data items that are similar to each others yet slightly different from each others.
Test cases, deployment descriptors, mob characters, or Tetsuya Komuro's pieces.
In general programming languages, many techniques have been developed such as class inheritance, interface, library function, macro, etc., etc.
However, in recent data notations such as JSON, YAML, HCL, etc. this is a concern not seriously taken into account.
One approach is HOCON, which is yet another data notation.
The approach jq-front
takes is a bit different.
Instead of coming up with a new data notation, it introduces several keywords into JSON, which is used as a subset of newer notations and which you can always convert them into as a matter of fact.
By taking this approach, you can write your YAML, HCL, HOCON files, using the keywords specified by jq-front
.
Thus, you can enjoy the benefit of the benefits of them and at the same time the functionalities of jq-front
.
It provides inheritance of JSON files, references between JSON nodes, computation of a node value from another, and more.
But note that it's slow because it's written in bash
.
I didn't notice this tool can be useful this much when I started writing it.
I am planning to re-write it in a full-fledge language like Java (or golang?) to create a faster version of jq-front
.
Maybe you wonder if it's tested enough. Don't worry about that. It's quite well tested and you can check the test suite here: https://github.com/dakusui/jq-front/tree/master/tests I hope your product is better tested than this ;)
jq-front [-h|--help] [--validation=no|strict|lenient] [--nested-templating-levels=num] [--version] [TARGET]
-h
,--help
: Shows a help--validation
: Validation mode.no
,strict
, andlenient
are available.--nested-templating-levels:
Number of times templating happens in the process. The default is 5. If templating doesn’t finish withinnum
times, an error will be reported.--version
: Shows a version.TARGET
: A file to be processed. If not given,stdin
will be processed
Let's prepare files, name.json
and greeting.json
, from which you want to create a new JSON by extending them.
$ echo '{"yourname":"Mark"}' > name.json
$ cat name.json
{"yourname":"Mark"}
$ echo '{"greeting":"Hello"}' > greeting.json
$ cat greeting.json
{"greeting":"Hello"}
Then create a file that extends them.
$ echo '{
"$extends": ["greeting.json", "name.json"],
"sayHello": "eval:$(ref .greeting), $(ref .yourname). Toady is $(date). How are you doing?"
}' > sayHello.json
Now, let's try jq-front
.
$ jq-front sayHello.json
{
"yourname": "Mark",
"greeting": "Hello",
"sayHello": "Hello, Mark. Toady is Fri Aug 30 22:04:40 UTC 2019. How are you doing?"
}
$
Doesn't it seem useful? Have fun!
Place the file jq-front
, lib
, and schema
somewhere on your PATH
.
Following tools are used to develop jq-front
.
A version for each tool used for development and testing are found in parentheses.
bash
(5.0.17
)jq
(1.6
)npm
(6.14.4
)yamljs
(0.3.0
)
Refer to the Dockerfile
for procedure to set up development environment.
Add a following entry to your .bashrc
or a file sourced through it.
function jq-front() {
docker run --rm -i \
-v "${HOME}:/var/lib/jf/${HOME}" \
-v "${HOME}/.jq-front.rc:/root/.jq-front.rc" \
-e JF_PATH_BASE="/var/lib/jf" \
-e JF_PATH="${JF_PATH}" \
-e JF_DEBUG=${JF_DEBUG:-disabled} \
-e JF_CWD="$(pwd)" \
dakusui/jq-front:"${JF_DOCKER_TAG:-v0.57}" "${@}"
}
NOTE: This approach allows you to process files only under /home/hiroshi
directory.
- File Level Inheritance
- Node Level Inheritance
- Templating (rendering text nodes referring to other nodes' values)
- Validation (strict and lenient validations)
You can find more about this product here.
- Install dependencies mentioned in the Installation section.
- Install docker
-
Option 1
- Fork this repo.
- If you have an account in Docker Hub, it might be a good idea to update
DOCKER_USER_NAME
inbuild_info.sh
with yours to be able to publish your own image.
-
Option 2
- Clone this repo to your local machine using
https://github.com/dakusui/jq-front.git
- Clone this repo to your local machine using
The build procedure of this project can only work on Ubuntu currently.
bulid.sh
is the tool with which you can generate documentation, perform tests, and package the tool as a docker image.
Every time it is invoked it prepares some resources before executing any tasks.
The tool scans the directory res
and performs a templating on every file.
The scan happens in an alphabetical order of the names of the files.
And each templated file will be copied to a corresponding directory from the current.
That is, if you have a file res/dir1/hello-world.txt
, it will be templated and copied to dir1/hello-world.txt
.
In case a file's name starts with a digit([0-9]
) and contains an underscore(_
), the file will be templated and copied to a file whose name doesn't have the portion.
res/0hello_hello.txt
will be rendered to hello.txt
.
This behaviour is useful when you want to include a content of another file, whose name comes latter in an alphabetical order than the file you are editing.
Note that dollar signs($
) contained by files under res
directory need to be escaped by a backslash(\
).
- Technical documents are stored under
docs
directory in.adoc
format. - Documentation format is
asciidoc
..html
files are generated automatically. Please don't edit them. - Note that
README.md
is generated fromres/README.md
in resource preparation mechanism of thebuild.sh
. In case you want to update, editres/README.md
.
HACK AWAY! 🔨🔨🔨
Please do not forget adding test cases under tests
directory.
Probably tests/single
directory contains a first example that you can follow.
Please do
$ ./build.sh PACKAGE
This will execute following tasks after resource preparation is finished.
- Build documentation.
- Run tests.
- Create a Docker image.
- Run the same tests using the docker image.
- 🔃 Create a new pull request using
https://github.com/dakusui/jq-front/compare/
. Please do not forget running tests to ensure that auto-generated resources up-to-date. Also please do not forget removing your custom configuration made onbuild_info.sh
.
- Hrioshi Ukai - Initial work - dakusui
- MIT license
- Copyright 2019 © Hiroshi Ukai.