[package]
edition = "2021"
rust-version = "1.82.0"
name = "lance-index"
version = "2.0.0"
authors = ["Lance Devs <dev@lance.org>"]
build = "build.rs"
autolib = false
autobins = false
autoexamples = false
autotests = false
autobenches = false
description = "Lance indices implementation"
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 = ["protoc"]
[features]
protoc = ["dep:protobuf-src"]
tokenizer-jieba = ["dep:jieba-rs"]
tokenizer-lindera = [
"dep:lindera",
"dep:lindera-tantivy",
]
[lib]
name = "lance_index"
path = "src/lib.rs"
[[bench]]
name = "4bitpq_dist_table"
path = "benches/4bitpq_dist_table.rs"
harness = false
[[bench]]
name = "bitmap"
path = "benches/bitmap.rs"
harness = false
[[bench]]
name = "btree"
path = "benches/btree.rs"
harness = false
[[bench]]
name = "common"
path = "benches/common.rs"
[[bench]]
name = "compute_partition"
path = "benches/compute_partition.rs"
harness = false
[[bench]]
name = "find_partitions"
path = "benches/find_partitions.rs"
harness = false
[[bench]]
name = "geo"
path = "benches/geo.rs"
harness = false
[[bench]]
name = "hnsw"
path = "benches/hnsw.rs"
harness = false
[[bench]]
name = "inverted"
path = "benches/inverted.rs"
harness = false
[[bench]]
name = "kmeans"
path = "benches/kmeans.rs"
harness = false
[[bench]]
name = "ngram"
path = "benches/ngram.rs"
harness = false
[[bench]]
name = "pq_assignment"
path = "benches/pq_assignment.rs"
harness = false
[[bench]]
name = "pq_dist_table"
path = "benches/pq_dist_table.rs"
harness = false
[[bench]]
name = "rq"
path = "benches/rq.rs"
harness = false
[[bench]]
name = "sq"
path = "benches/sq.rs"
harness = false
[[bench]]
name = "zonemap"
path = "benches/zonemap.rs"
harness = false
[dependencies.arrow]
version = "57.0.0"
features = ["prettyprint"]
[dependencies.arrow-arith]
version = "57.0.0"
[dependencies.arrow-array]
version = "57.0.0"
[dependencies.arrow-ord]
version = "57.0.0"
[dependencies.arrow-schema]
version = "57.0.0"
[dependencies.arrow-select]
version = "57.0.0"
[dependencies.async-channel]
version = "2.3.1"
[dependencies.async-recursion]
version = "1.0"
[dependencies.async-trait]
version = "0.1"
[dependencies.bitpacking]
version = "0.9.2"
features = ["bitpacker4x"]
[dependencies.bitvec]
version = "1"
[dependencies.bytes]
version = "1.4"
[dependencies.crossbeam-queue]
version = "0.3"
[dependencies.datafusion]
version = "51.0.0"
features = [
"nested_expressions",
"regex_expressions",
"unicode_expressions",
"crypto_expressions",
"encoding_expressions",
"datetime_expressions",
"sql",
"string_expressions",
]
default-features = false
[dependencies.datafusion-common]
version = "51.0.0"
[dependencies.datafusion-expr]
version = "51.0.0"
[dependencies.datafusion-physical-expr]
version = "51.0.0"
[dependencies.datafusion-sql]
version = "51.0.0"
[dependencies.deepsize]
version = "0.2.0"
[dependencies.dirs]
version = "6.0.0"
[dependencies.fst]
version = "0.4.7"
features = ["levenshtein"]
[dependencies.futures]
version = "0.3"
[dependencies.geo-types]
version = "0.7.16"
[dependencies.geoarrow-array]
version = "0.7"
[dependencies.geoarrow-schema]
version = "0.7"
[dependencies.half]
version = "2.1"
features = [
"num-traits",
"std",
]
default-features = false
[dependencies.itertools]
version = "0.13"
[dependencies.jieba-rs]
version = "0.8.1"
optional = true
default-features = false
[dependencies.jsonb]
version = "0.5.3"
features = ["databend"]
default-features = false
[dependencies.lance-arrow]
version = "=2.0.0"
[dependencies.lance-core]
version = "=2.0.0"
[dependencies.lance-datafusion]
version = "=2.0.0"
[dependencies.lance-datagen]
version = "=2.0.0"
[dependencies.lance-encoding]
version = "=2.0.0"
[dependencies.lance-file]
version = "=2.0.0"
[dependencies.lance-geo]
version = "=2.0.0"
[dependencies.lance-io]
version = "=2.0.0"
default-features = false
[dependencies.lance-linalg]
version = "=2.0.0"
[dependencies.lance-table]
version = "=2.0.0"
[dependencies.libm]
version = "0.2.15"
[dependencies.lindera]
version = "0.44.0"
optional = true
[dependencies.lindera-tantivy]
version = "0.44.0"
optional = true
[dependencies.log]
version = "0.4"
[dependencies.ndarray]
version = "0.16.1"
features = ["matrixmultiply-threading"]
[dependencies.num-traits]
version = "0.2"
[dependencies.object_store]
version = "0.12.3"
[dependencies.prost]
version = "0.14.1"
[dependencies.prost-types]
version = "0.14.1"
[dependencies.rand]
version = "0.9.1"
features = ["small_rng"]
[dependencies.rand_distr]
version = "0.5.1"
[dependencies.rangemap]
version = "1.0"
[dependencies.rayon]
version = "1.10"
[dependencies.roaring]
version = "0.10.1"
[dependencies.serde]
version = "^1"
[dependencies.serde_json]
version = "1"
[dependencies.smallvec]
version = "1.15"
[dependencies.snafu]
version = "0.8"
[dependencies.tantivy]
version = "0.24.1"
features = ["stopwords"]
[dependencies.tempfile]
version = "3"
[dependencies.tokio]
version = "1.23"
features = [
"rt-multi-thread",
"macros",
"fs",
"sync",
]
[dependencies.tracing]
version = "0.1"
[dependencies.twox-hash]
version = "2.0"
[dependencies.uuid]
version = "1.2"
features = [
"v4",
"serde",
]
[dev-dependencies.approx]
version = "0.5.1"
[dev-dependencies.chrono]
version = "0.4.41"
features = [
"std",
"now",
"serde",
]
default-features = false
[dev-dependencies.criterion]
version = "0.5"
features = [
"async",
"async_tokio",
"html_reports",
]
[dev-dependencies.env_logger]
version = "0.11.6"
[dev-dependencies.geo-traits]
version = "0.3.0"
[dev-dependencies.lance-datagen]
version = "=2.0.0"
[dev-dependencies.lance-testing]
version = "=2.0.0"
[dev-dependencies.rstest]
version = "0.23.0"
[dev-dependencies.test-log]
version = "0.2.15"
[build-dependencies.prost-build]
version = "0.14.1"
[build-dependencies.protobuf-src]
version = "2.1"
optional = true
[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"
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
[lints.rust.unexpected_cfgs]
level = "warn"
priority = 0
check-cfg = ["cfg(coverage,coverage_nightly)"]