Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pro-2684/scheval
A fast and *smart* command-line tool for JSON Schema validation, powered by the `jsonschema` crate.
https://github.com/pro-2684/scheval
cli json-schema rust
Last synced: 3 days ago
JSON representation
A fast and *smart* command-line tool for JSON Schema validation, powered by the `jsonschema` crate.
- Host: GitHub
- URL: https://github.com/pro-2684/scheval
- Owner: PRO-2684
- License: mit
- Created: 2024-12-23T08:42:11.000Z (about 2 months ago)
- Default Branch: main
- Last Pushed: 2025-02-10T02:49:39.000Z (11 days ago)
- Last Synced: 2025-02-10T03:26:57.003Z (11 days ago)
- Topics: cli, json-schema, rust
- Language: Rust
- Homepage: https://crates.io/crates/scheval
- Size: 157 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# scheval
[data:image/s3,"s3://crabby-images/8c16b/8c16b3b75398dbb2fbc891a12815e4b47e953777" alt="GitHub License"](https://github.com/PRO-2684/scheval/blob/main/LICENSE)
[data:image/s3,"s3://crabby-images/f0d7d/f0d7d250a7303cbc056222947bb771cd16bae16a" alt="GitHub Workflow Status"](https://github.com/PRO-2684/scheval/blob/main/.github/workflows/release.yml)
[data:image/s3,"s3://crabby-images/d3abb/d3abbe92b56eefc0d8cd66e04ac158c7898118f9" alt="GitHub Release"](https://github.com/PRO-2684/scheval/releases)
[data:image/s3,"s3://crabby-images/6340d/6340d6112ae590d58a6d0cf0c27a542bfc7bb12d" alt="GitHub Downloads (all assets, all releases)"](https://github.com/PRO-2684/scheval/releases)
[data:image/s3,"s3://crabby-images/8d813/8d813dd1c25a1c638f22b70b4f79168f8fcbe9d8" alt="GitHub Downloads (all assets, latest release)"](https://github.com/PRO-2684/scheval/releases/latest)
[data:image/s3,"s3://crabby-images/31f5c/31f5c7ad9268649967aaa38ac4d2f642f1d68fa3" alt="Crates.io Version"](https://crates.io/crates/scheval)
[data:image/s3,"s3://crabby-images/51b40/51b404d8fa242511eb622c0cc7e09fed21426b8d" alt="Crates.io Total Downloads"](https://crates.io/crates/scheval)A fast and *smart* command-line tool for JSON Schema validation, powered by the `jsonschema` crate. Currently still in development.
## 🚀 Installation
If you have `cargo-binstall`, you can install this tool by running:
```shell
$ cargo binstall scheval
```Otherwise, you can install it from source:
```shell
$ cargo install scheval
```## ✨ Features
### Including
- `vscode`: Respect `json.schemas` field at `.vscode/settings.json` if present
- `suffix`: Validate `.json` with `.schema.json` under working directory### Excluding
TBD
## 🚀 Quick Start
`scheval` can be run without any arguments. It will automatically use all available features.
```shell
$ scheval
```Alternatively, you can specify a list of smart including features to use:
```shell
$ scheval --include vscode # Uses only `vscode`
$ scheval --include suffix # Uses only `suffix`
$ scheval --include vscode --include suffix # Uses both `vscode` and `suffix`
$ # Shorthands provided by `clap`
$ scheval -i vscode -i suffix
$ scheval -ivscode -isuffix
```## 📚 Usage
```shell
$ scheval --help
A fast and *smart* command-line tool for JSON Schema validation, powered by the `jsonschema` crate.Usage: scheval [OPTIONS]
Options:
-i, --include
What smart including features to use. Available: `vscode`, `suffix`. Default to all- `vscode`: Respect `json.schemas` field at `.vscode/settings.json` if present
- `suffix`: Validate `.json` with `.schema.json` under working directory-h, --help
Print help (see a summary with '-h')-V, --version
Print version
```## 📝 Notes
This project uses [`globwalk`](https://github.com/Gilnaa/globwalk) for pattern matching, which might be buggy. Notably in `fileMatch` field:
- `./` is not supported (I've included a quick fix by removing the prefix, but have not considered other cases, like `././` or `!./`)
- `../` is not supported (A warning will be shown, and the pattern will be ignored)If you have a good alternative which supports [VSCode's `fileMatch` syntax](https://code.visualstudio.com/docs/languages/json#_file-match-syntax), please let me know.
Possible alternatives:
- [globset](https://docs.rs/globset/)
- [ignore](https://docs.rs/ignore/)## TODO
- [ ] Implement `vscode` auto detection
- [x] Better support for `fileMatch`
- [x] Relative path
- [x] Absolute path (workspace)
- [ ] Support for `url`
- [x] Local schema (path)
- [ ] Remote schema (URL)
- [x] Support for `schema` (Inline schema)
- [ ] Smartly exclude paths
- [ ] Add more tests & documentation
- [ ] Better error handling
- [ ] Output
- [ ] Handle output in `main.rs`
- [ ] Use commandline argument `--verbose` for increased verbosity
- [x] Colorize output (https://docs.rs/anstyle or https://docs.rs/colored)
- [ ] Improve performance using references
- [ ] Possibly adding more features
- [x] [Reduce binary size](https://github.com/johnthagen/min-sized-rust)
- [x] Automation using GitHub Actions
- [x] Release (respecting `cargo-binstall`)
- [x] Publish