[package]
edition = "2024"
rust-version = "1.88.0"
name = "datafusion-expr"
version = "52.1.0"
authors = ["Apache DataFusion <dev@datafusion.apache.org>"]
build = false
autolib = false
autobins = false
autoexamples = false
autotests = false
autobenches = false
description = "Logical plan and expression representation for DataFusion query engine"
homepage = "https://datafusion.apache.org"
readme = "README.md"
keywords = [
"datafusion",
"logical",
"plan",
"expressions",
]
license = "Apache-2.0"
repository = "https://github.com/apache/datafusion"
resolver = "2"
[package.metadata.docs.rs]
all-features = true
[features]
default = ["sql"]
recursive_protection = ["dep:recursive"]
sql = ["sqlparser"]
[lib]
name = "datafusion_expr"
path = "src/lib.rs"
[dependencies.arrow]
version = "57.1.0"
features = [
"prettyprint",
"chrono-tz",
]
[dependencies.async-trait]
version = "0.1.89"
[dependencies.chrono]
version = "0.4.42"
default-features = false
[dependencies.datafusion-common]
version = "52.1.0"
default-features = false
[dependencies.datafusion-doc]
version = "52.1.0"
[dependencies.datafusion-expr-common]
version = "52.1.0"
[dependencies.datafusion-functions-aggregate-common]
version = "52.1.0"
[dependencies.datafusion-functions-window-common]
version = "52.1.0"
[dependencies.datafusion-physical-expr-common]
version = "52.1.0"
default-features = false
[dependencies.indexmap]
version = "2.12.1"
[dependencies.itertools]
version = "0.14"
[dependencies.paste]
version = "1.0.15"
[dependencies.recursive]
version = "0.1.1"
optional = true
[dependencies.serde_json]
version = "1"
[dependencies.sqlparser]
version = "0.59.0"
features = [
"std",
"visitor",
]
optional = true
default-features = false
[dev-dependencies.ctor]
version = "0.6.3"
[dev-dependencies.env_logger]
version = "0.11"
[dev-dependencies.insta]
version = "1.46.0"
features = [
"glob",
"filters",
]
[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)",
]