[package]
edition = "2024"
rust-version = "1.88.0"
name = "datafusion-substrait"
version = "52.1.0"
authors = ["Apache DataFusion <dev@datafusion.apache.org>"]
build = false
autolib = false
autobins = false
autoexamples = false
autotests = false
autobenches = false
description = "DataFusion Substrait Producer and Consumer"
homepage = "https://datafusion.apache.org"
readme = "README.md"
license = "Apache-2.0"
repository = "https://github.com/apache/datafusion"
resolver = "2"
[package.metadata.docs.rs]
all-features = true
[features]
default = ["physical"]
physical = ["datafusion/parquet"]
protoc = ["substrait/protoc"]
[lib]
name = "datafusion_substrait"
path = "src/lib.rs"
[[test]]
name = "substrait_integration"
path = "tests/substrait_integration.rs"
[[test]]
name = "utils"
path = "tests/utils.rs"
[dependencies.async-recursion]
version = "1.0"
[dependencies.async-trait]
version = "0.1.89"
[dependencies.chrono]
version = "0.4.42"
default-features = false
[dependencies.datafusion]
version = "52.1.0"
features = ["sql"]
default-features = false
[dependencies.half]
version = "2.7.0"
default-features = false
[dependencies.itertools]
version = "0.14"
[dependencies.object_store]
version = "0.12.4"
default-features = false
[dependencies.pbjson-types]
version = "0.8"
[dependencies.prost]
version = "0.14.1"
[dependencies.substrait]
version = "0.62"
features = ["serde"]
[dependencies.tokio]
version = "1.48"
features = [
"macros",
"rt",
"sync",
"fs",
]
[dependencies.url]
version = "2.5.7"
[dependencies.uuid]
version = "1.19.0"
features = ["v4"]
[dev-dependencies.datafusion]
version = "52.1.0"
features = [
"nested_expressions",
"unicode_expressions",
]
default-features = false
[dev-dependencies.datafusion-functions-aggregate]
version = "52.1.0"
[dev-dependencies.insta]
version = "1.46.0"
features = [
"glob",
"filters",
]
[dev-dependencies.serde_json]
version = "1"
[dev-dependencies.tokio]
version = "1.48"
features = [
"macros",
"rt",
"sync",
]
[lints.clippy]
inefficient_to_string = "warn"
large_futures = "warn"
needless_pass_by_value = "warn"
or_fun_call = "warn"
uninlined_format_args = "warn"
unnecessary_lazy_evaluations = "warn"
used_underscore_binding = "warn"
[lints.rust]
unused_qualifications = "deny"
[lints.rust.unexpected_cfgs]
level = "warn"
priority = 0
check-cfg = [
'cfg(datafusion_coop, values("tokio", "tokio_fallback", "per_stream"))',
"cfg(tarpaulin)",
"cfg(tarpaulin_include)",
]