[package]
edition = "2021"
rust-version = "1.82.0"
name = "lance"
version = "1.0.4"
authors = ["Lance Devs <dev@lance.org>"]
build = false
autolib = false
autobins = false
autoexamples = false
autotests = false
autobenches = false
description = "A columnar data format that is 100x faster than Parquet for random access."
readme = "README.md"
keywords = [
"data-format",
"data-science",
"machine-learning",
"apache-arrow",
"data-analytics",
]
categories = [
"database-implementations",
"data-structures",
"development-tools",
"science",
]
license = "Apache-2.0"
repository = "https://github.com/lance-format/lance"
[package.metadata.docs.rs]
features = []
no-default-features = true
[features]
aws = [
"lance-io/aws",
"dep:aws-credential-types",
]
azure = ["lance-io/azure"]
cli = [
"dep:clap",
"lzma-sys/static",
]
default = [
"aws",
"azure",
"gcp",
"oss",
"huggingface",
]
dynamodb = [
"lance-table/dynamodb",
"dep:aws-sdk-dynamodb",
]
dynamodb_tests = ["dynamodb"]
fp16kernels = ["lance-linalg/fp16kernels"]
gcp = ["lance-io/gcp"]
huggingface = ["lance-io/huggingface"]
oss = ["lance-io/oss"]
protoc = [
"lance-encoding/protoc",
"lance-file/protoc",
"lance-index/protoc",
"lance-table/protoc",
]
substrait = ["lance-datafusion/substrait"]
[lib]
name = "lance"
path = "src/lib.rs"
[[bin]]
name = "lq"
path = "src/bin/lq.rs"
required-features = ["cli"]
[[test]]
name = "resource_tests"
path = "tests/resource_tests.rs"
[[bench]]
name = "ivf_pq"
path = "benches/ivf_pq.rs"
harness = false
[[bench]]
name = "random_access"
path = "benches/random_access.rs"
harness = false
[[bench]]
name = "scalar_index"
path = "benches/scalar_index.rs"
harness = false
[[bench]]
name = "scan"
path = "benches/scan.rs"
harness = false
[[bench]]
name = "take"
path = "benches/take.rs"
harness = false
[[bench]]
name = "vector_index"
path = "benches/vector_index.rs"
harness = false
[dependencies.arrow]
version = "56.1"
features = ["prettyprint"]
[dependencies.arrow-arith]
version = "56.1"
[dependencies.arrow-array]
version = "56.1"
[dependencies.arrow-buffer]
version = "56.1"
[dependencies.arrow-ipc]
version = "56.1"
features = ["zstd"]
[dependencies.arrow-ord]
version = "56.1"
[dependencies.arrow-row]
version = "56.1"
[dependencies.arrow-schema]
version = "56.1"
[dependencies.arrow-select]
version = "56.1"
[dependencies.async-recursion]
version = "1.0"
[dependencies.async-trait]
version = "0.1"
[dependencies.async_cell]
version = "0.2.2"
[dependencies.aws-credential-types]
version = "1.2.0"
optional = true
[dependencies.aws-sdk-dynamodb]
version = "1.38.0"
optional = true
[dependencies.byteorder]
version = "1.5"
[dependencies.bytes]
version = "1.4"
[dependencies.chrono]
version = "0.4.41"
features = [
"std",
"now",
"serde",
]
default-features = false
[dependencies.clap]
version = "4.1.1"
features = ["derive"]
optional = true
[dependencies.dashmap]
version = "6"
[dependencies.datafusion]
version = "50.0.0"
features = [
"nested_expressions",
"regex_expressions",
"unicode_expressions",
"crypto_expressions",
"encoding_expressions",
"datetime_expressions",
"string_expressions",
]
default-features = false
[dependencies.datafusion-expr]
version = "50.0.0"
[dependencies.datafusion-functions]
version = "50.0.0"
features = ["regex_expressions"]
[dependencies.datafusion-physical-expr]
version = "50.0.0"
[dependencies.datafusion-physical-plan]
version = "50.0.0"
[dependencies.deepsize]
version = "0.2.0"
[dependencies.either]
version = "1.0"
[dependencies.futures]
version = "0.3"
[dependencies.half]
version = "2.1"
features = [
"num-traits",
"std",
]
default-features = false
[dependencies.humantime]
version = "2.2.0"
[dependencies.itertools]
version = "0.13"
[dependencies.lance-arrow]
version = "=1.0.4"
[dependencies.lance-core]
version = "=1.0.4"
[dependencies.lance-datafusion]
version = "=1.0.4"
[dependencies.lance-encoding]
version = "=1.0.4"
[dependencies.lance-file]
version = "=1.0.4"
[dependencies.lance-geo]
version = "=1.0.4"
[dependencies.lance-index]
version = "=1.0.4"
[dependencies.lance-io]
version = "=1.0.4"
default-features = false
[dependencies.lance-linalg]
version = "=1.0.4"
[dependencies.lance-namespace]
version = "=1.0.4"
[dependencies.lance-table]
version = "=1.0.4"
[dependencies.lapack]
version = "0.19.0"
optional = true
[dependencies.log]
version = "0.4"
[dependencies.moka]
version = "0.12"
features = [
"future",
"sync",
]
[dependencies.object_store]
version = "0.12.3"
[dependencies.permutation]
version = "0.4.0"
[dependencies.pin-project]
version = "1.0"
[dependencies.prost]
version = "0.13.2"
[dependencies.prost-types]
version = "0.13.2"
[dependencies.rand]
version = "0.9.1"
features = ["small_rng"]
[dependencies.roaring]
version = "0.10.1"
[dependencies.semver]
version = "1.0"
[dependencies.serde]
version = "^1"
[dependencies.serde_json]
version = "1"
[dependencies.snafu]
version = "0.8"
[dependencies.tantivy]
version = "0.24.1"
features = ["stopwords"]
[dependencies.tokio]
version = "1.23"
features = [
"rt-multi-thread",
"macros",
"fs",
"sync",
]
[dependencies.tokio-stream]
version = "0.1.14"
[dependencies.tracing]
version = "0.1"
[dependencies.url]
version = "2.5.7"
[dependencies.uuid]
version = "1.2"
features = [
"v4",
"serde",
]
[dev-dependencies.all_asserts]
version = "2.3.1"
[dev-dependencies.approx]
version = "0.5.1"
[dev-dependencies.aws-config]
version = "1.2.0"
[dev-dependencies.aws-sdk-s3]
version = "1.38.0"
[dev-dependencies.clap]
version = "4"
features = [
"derive",
"derive",
]
[dev-dependencies.criterion]
version = "0.5"
features = [
"async",
"async_tokio",
"html_reports",
]
[dev-dependencies.dirs]
version = "5.0.0"
[dev-dependencies.env_logger]
version = "0.11.7"
[dev-dependencies.geo-types]
version = "0.7.16"
[dev-dependencies.geoarrow-array]
version = "0.6"
[dev-dependencies.geoarrow-schema]
version = "0.6"
[dev-dependencies.lance-datagen]
version = "=1.0.4"
[dev-dependencies.lance-io]
version = "=1.0.4"
features = ["test-util"]
default-features = false
[dev-dependencies.lance-test-macros]
version = "=1.0.4"
[dev-dependencies.lance-testing]
version = "=1.0.4"
[dev-dependencies.mock_instant]
version = "0.6.0"
[dev-dependencies.pretty_assertions]
version = "1.4.0"
[dev-dependencies.rstest]
version = "0.23.0"
[dev-dependencies.tempfile]
version = "3"
[dev-dependencies.test-log]
version = "0.2.15"
[dev-dependencies.tracing-chrome]
version = "0.7.1"
[dev-dependencies.tracing-subscriber]
version = "0.3.17"
features = ["env-filter"]
[dev-dependencies.tracking-allocator]
version = "0.4"
features = ["tracing-compat"]
[target.'cfg(target_os = "linux")'.dev-dependencies.lzma-sys]
version = "0.1"
[target.'cfg(target_os = "linux")'.dev-dependencies.pprof]
version = "0.14.0"
features = [
"flamegraph",
"criterion",
]
[lints.clippy]
dbg_macro = "deny"
fallible_impl_from = "deny"
large_futures = "deny"
manual_let_else = "deny"
multiple-crate-versions = "allow"
print_stderr = "deny"
print_stdout = "deny"
redundant_clone = "deny"
redundant_pub_crate = "deny"
single_range_in_vec_init = "allow"
string_add = "deny"
string_add_assign = "deny"
string_lit_as_bytes = "deny"
string_to_string = "deny"
trait_duplication_in_bounds = "deny"
use_self = "deny"
[lints.clippy.all]
level = "deny"
priority = -1
[lints.clippy.cargo]
level = "deny"
priority = -1
[lints.clippy.style]
level = "deny"
priority = -1