![JQ::Lite](./images/JQ_Lite_sm.png) # 🧩 JQ::Lite β€” Lightweight jq in Pure Perl [![GitHub](https://img.shields.io/github/stars/kawamurashingo/JQ-Lite?style=social)](https://github.com/kawamurashingo/JQ-Lite) [![MetaCPAN](https://img.shields.io/cpan/v/JQ-Lite.svg)](https://metacpan.org/release/JQ-Lite) **JQ::Lite** is a pure-Perl JSON query engine inspired by [`jq`](https://stedolan.github.io/jq/). It allows you to query and transform JSON using jq-like syntax β€” without external binaries. --- ## ✨ Highlights * πŸͺΆ **Pure Perl** β€” no XS or C dependencies * πŸ” jq-style filters: `.users[].name`, `.nickname?`, `select(...)`, `map(...)` * πŸ”’ Supports arithmetic & conditionals: `if ... then ... else ... end` * πŸ”§ CLI tool: `jq-lite` with `--null-input`, `--slurp`, `--from-file`, `--yaml` * πŸ“Š Built-in 100+ jq functions (see [`FUNCTIONS.md`](FUNCTIONS.md)) * πŸ’» Interactive mode for exploring JSON * 🧰 Works with JSON or YAML input * 🌐 Compatible with almost any Linux (even legacy or air-gapped) (see [`VISION.md`](VISION.md)) --- ## πŸ’‘ Why Pure Perl? Unlike the original **jq** written in C, **JQ::Lite** is implemented entirely in Perl. This design choice brings several practical advantages: ### 🧩 Portability No compilation, no shared libraries β€” it runs anywhere Perl runs. Perfect for **restricted**, **legacy**, or **air-gapped** environments. ### 🧰 Extensibility Add or customize jq-like functions directly in Perl. Leverage CPAN modules (`LWP`, `DBI`, etc.) to integrate with APIs, databases, or filesystems. ### 🧱 Integration Use it seamlessly inside Perl scripts: ```perl use JQ::Lite; my $jq = JQ::Lite->new; say for $jq->run_query($json, '.users[].name'); ```` No need to call external binaries or parse command output. ### βš™οΈ Lightweight Installation No XS/C libraries or `make install` required β€” just `cpanm JQ::Lite` or the portable installer. Ideal for CI/CD pipelines or user-level installations. ### πŸ” Maintainability Perl’s expressive syntax allows faster development and debugging. Community patches and feature extensions are easier than C-level contributions. --- ## βš™οΈ Installation ### πŸ›  From CPAN ```bash cpanm JQ::Lite ``` ### 🍺 Homebrew (macOS) ```bash brew tap kawamurashingo/jq-lite brew install --HEAD jq-lite ``` --- ## 🐧 Portable Installer (Online β†’ Offline) **For air-gapped or offline systems** 1. **Download on a connected machine** ```bash ./download.sh [-v ] [-o /path/to/usb] ``` β†’ Produces `JQ-Lite-.tar.gz`. 2. **Transfer** the tarball to the target (offline) machine. 3. **Install (Linux/macOS)** ```bash ./install.sh [-p ] [--skip-tests] /path/to/JQ-Lite-.tar.gz ``` *Default install path:* `$HOME/.local` ```bash export PATH="$HOME/.local/bin:$PATH" export PERL5LIB="$HOME/.local/lib/perl5/site_perl:$PERL5LIB" ``` --- ## πŸͺŸ Windows (PowerShell) 1. Open PowerShell and run: ```powershell .\install-jq-lite.ps1 [-Prefix ] [--SkipTests] C:\path\to\JQ-Lite-.tar.gz ``` 2. Add to your PowerShell profile (optional): ```powershell $env:PATH = "$env:USERPROFILE\.local\bin;" + $env:PATH $env:PERL5LIB = "$env:USERPROFILE\.local\lib\perl5\site_perl;" + $env:PERL5LIB ``` 3. Verify: ```powershell jq-lite -v ``` --- ## πŸš€ Usage ### As a Perl module ```perl use JQ::Lite; my $jq = JQ::Lite->new; my @names = $jq->run_query('{"users":[{"name":"Alice"}]}', '.users[].name'); print join("\n", @names); ``` ### As a CLI tool ```bash jq-lite '.users[].name' users.json jq-lite '.users[] | select(.age > 25)' users.json jq-lite --yaml '.users[].name' users.yaml ``` πŸ’‘ Try interactive mode: ```bash jq-lite users.json ``` --- ## 🧱 Environment Support | Environment | jq | jq-lite | | -------------------- | -- | ------- | | Legacy CentOS / RHEL | ❌ | βœ… | | Alpine Linux | ⚠️ | βœ… | | Air-gapped / Proxy | ❌ | βœ… | | No root privilege | ⚠️ | βœ… | βœ… **Runs on Perl β‰₯ 5.14**, even on CentOS 6 or Debian 7 with `perlbrew` or local install. --- ## πŸ” Example Queries ```bash jq-lite '.users[] | select(.profile.active) | .name' users.json jq-lite '.users | sort_by(.age) | map(.name) | join(", ")' users.json jq-lite '.users[].nickname? // .name' users.json ``` --- ## 🧠 More Functions See the complete list in πŸ‘‰ [`FUNCTIONS.md`](FUNCTIONS.md) or on [MetaCPAN](https://metacpan.org/pod/JQ::Lite) --- ## πŸ‘€ Author **Shingo Kawamura** πŸ“§ [pannakoota1@gmail.com](mailto:pannakoota1@gmail.com) πŸ”— [GitHub @kawamurashingo](https://github.com/kawamurashingo/JQ-Lite) --- ## πŸ“œ License Same terms as Perl itself.