10 releases

new 0.3.5 Mar 12, 2025
0.3.4 Feb 21, 2025
0.3.2 Dec 9, 2024
0.3.1 Nov 14, 2024
0.1.0 Oct 8, 2024

#177 in Database interfaces

Download history 387/week @ 2024-11-21 109/week @ 2024-11-28 275/week @ 2024-12-05 241/week @ 2024-12-12 131/week @ 2024-12-19 15/week @ 2024-12-26 309/week @ 2025-01-02 95/week @ 2025-01-09 68/week @ 2025-01-16 57/week @ 2025-01-23 203/week @ 2025-01-30 563/week @ 2025-02-06 922/week @ 2025-02-13 617/week @ 2025-02-20 495/week @ 2025-02-27 274/week @ 2025-03-06

2,319 downloads per month
Used in 6 crates (2 directly)

MIT license

135KB
1.5K SLoC

cql2-rs

CI

Parse, validate, and convert Common Query Language (CQL2) text and JSON.

Usage

API

[dependencies]
cql = "0.3"

Then:

use cql2::Expr;

let expr: Expr = "landsat:scene_id = 'LC82030282019133LGN00'".parse().unwrap();
assert!(expr.is_valid());
println!("{}", expr.to_json().unwrap());

See the documentation for more.

CLI

See the cql2-cli README for details.

Responses

Responses may not match the input.

cql2-text differences

  • All identifiers in output are double quoted
  • The position of "NOT" keywords is standardized to be before the expression (ie "... NOT LIKE ..." will become "NOT ... LIKE ..."
  • The negative operator on anything besides a literal number becomes "* -1"
  • Parentheses are added around all expressions

Development

Get uv and Rust. Then:

git clone git@github.com:developmentseed/cql2-rs.git
cd cql2-rs
uv sync
scripts/test

To lint all files:

scripts/lint

To serve the docs locally:

uv run mkdocs serve  # http://127.0.0.1:8000/cql2-rs/

See CONTRIBUTING.md for more information about contributing to this project.

License

cql2-rs is licensed under the MIT license. See LICENSE for details.

Dependencies

~23–31MB
~480K SLoC