12 releases
new 0.1.3 | Jan 10, 2025 |
---|---|
0.1.1 | Nov 8, 2024 |
0.0.11 | Nov 29, 2022 |
0.0.9 | Oct 13, 2022 |
0.0.1 | Mar 30, 2022 |
#173 in Parser implementations
357,135 downloads per month
1MB
23K
SLoC
Contains (WOFF font, 155KB) src/export/html/fa-solid-900.woff2
Substrait query plan validator
This crate implements a validator for Substrait query plans.
[dependencies]
substrait-validator = "0.1.3"
YAML file resolution
One of the complexities of validating Substrait plans is resolving the YAML
extension files. By default, the crate only supports file://...
URLs, but
often, the YAML files will be stored remotely. To make handling this easier,
you can enable curl as an optional
dependency:
[dependencies]
substrait-validator = { version = "0.1.3", features = ["curl"] }
This adds the substrait_validator::Config::add_curl_yaml_uri_resolver()
method, which will use libcurl
to resolve the files, thus supporting all the
common protocols (http, https, ftp, etc.). The downside is that the curl crate
depends on system libraries.
lib.rs
:
Crate for validating Substrait.
Usage
The usage pattern is roughly as follows.
- Build a
Config
structure to configure the validator. You can also just usestd::default::Default
if you don't need to configure anything, but you might want to at least callConfig::add_curl_uri_resolver()
(if you're using thecurl
feature). - Parse the incoming
substrait.Plan
message using [parse()
] or [validate()
]. This creates a [ParseResult], containing a tree structure corresponding to the query plan that also contains diagnostics and other annotations added by the validator. - You can traverse the tree yourself using ParseResult::root, or you can use one of the methods associated with [ParseResult] to obtain the validation results you need.
Note that only the binary protobuf serialization format is supported at the
input; the JSON format is not supported. This is a limitation of prost
,
the crate that was used for protobuf deserialization. If you're looking for
a library (or CLI) that supports more human-friendly input, check out the
Python bindings.
Dependencies
~15–29MB
~440K SLoC