[package]
edition = "2024"
rust-version = "1.91.1"
name = "icechunk"
version = "2.0.2"
authors = ["Earthmover PBC"]
build = false
publish = true
autolib = false
autobins = false
autoexamples = false
autotests = false
autobenches = false
description = "Transactional storage engine for Zarr designed for use on cloud object storage"
homepage = "https://icechunk.io"
readme = "README.md"
keywords = [
"zarr",
"xarray",
"database",
]
categories = [
"database",
"science",
"science::geo",
]
license = "Apache-2.0"
repository = "https://github.com/earth-mover/icechunk"
resolver = "2"
[package.metadata.cargo-machete]
ignored = ["serde_bytes"]
[features]
cli = [
"dep:clap",
"dep:anyhow",
"dep:dialoguer",
"dep:dirs",
]
default = [
"s3",
"object-store-s3",
"object-store-gcs",
"object-store-azure",
"object-store-http",
"object-store-fs",
"redirect",
]
logs = ["dep:tracing-subscriber"]
napi-send-contract = []
object-store-azure = ["icechunk-arrow-object-store/azure"]
object-store-fs = ["icechunk-arrow-object-store/fs"]
object-store-gcs = ["icechunk-arrow-object-store/gcs"]
object-store-http = ["icechunk-arrow-object-store/http"]
object-store-s3 = ["icechunk-arrow-object-store/s3"]
redirect = ["dep:reqwest"]
s3 = ["dep:icechunk-s3"]
shuttle = []
[lib]
name = "icechunk"
path = "src/lib.rs"
[[bin]]
name = "icechunk"
path = "src/bin/icechunk/main.rs"
required-features = ["cli"]
[[example]]
name = "large_manifests"
path = "examples/large_manifests.rs"
[[example]]
name = "large_repo_info"
path = "examples/large_repo_info.rs"
[[example]]
name = "limits_chunk_refs"
path = "examples/limits_chunk_refs.rs"
[[example]]
name = "low_level_dataset"
path = "examples/low_level_dataset.rs"
[[example]]
name = "multithreaded_get_chunk_refs"
path = "examples/multithreaded_get_chunk_refs.rs"
[[example]]
name = "multithreaded_store"
path = "examples/multithreaded_store.rs"
[[test]]
name = "main"
path = "tests/main.rs"
[[test]]
name = "test_shuttle"
path = "tests/test_shuttle.rs"
[[bench]]
name = "main"
path = "benches/main.rs"
harness = false
[dependencies.anyhow]
version = "1.0.102"
optional = true
[dependencies.async-compression]
version = "0.4.41"
features = [
"tokio",
"zstd",
]
[dependencies.async-recursion]
version = "1.1.1"
[dependencies.async-stream]
version = "0.3.6"
[dependencies.async-trait]
version = "0.1.89"
[dependencies.backon]
version = "1.6.0"
[dependencies.bytes]
version = "1.11.1"
features = ["serde"]
[dependencies.chrono]
version = "0.4.44"
features = ["serde"]
[dependencies.clap]
version = "4.6"
features = ["derive"]
optional = true
[dependencies.dialoguer]
version = "0.12.0"
optional = true
[dependencies.dirs]
version = "6.0.0"
optional = true
[dependencies.flexbuffers]
version = "25.12.19"
[dependencies.futures]
version = "0.3.32"
[dependencies.icechunk-arrow-object-store]
version = "2.0.2"
default-features = false
[dependencies.icechunk-format]
version = "2.0.2"
[dependencies.icechunk-s3]
version = "2.0.2"
optional = true
[dependencies.icechunk-storage]
version = "2.0.2"
[dependencies.icechunk-types]
version = "2.0.2"
[dependencies.itertools]
version = "0.14.0"
[dependencies.quick_cache]
version = "0.6.21"
[dependencies.rand]
version = "0.10.1"
[dependencies.regex]
version = "1.12.3"
[dependencies.reqwest]
version = "0.13"
optional = true
[dependencies.rmp-serde]
version = "1.3.1"
[dependencies.serde]
version = "1.0.228"
features = [
"derive",
"rc",
]
[dependencies.serde_bytes]
version = "0.11.19"
[dependencies.serde_json]
version = "1.0.149"
[dependencies.serde_with]
version = "3.18.0"
features = ["hex"]
[dependencies.serde_yaml_ng]
version = "0.10.0"
[dependencies.thiserror]
version = "2.0.18"
[dependencies.tracing]
version = "0.1.44"
[dependencies.tracing-error]
version = "0.2.1"
[dependencies.tracing-subscriber]
version = "0.3.23"
features = ["env-filter"]
optional = true
[dependencies.typetag]
version = "0.2.21"
[dependencies.url]
version = "2.5.8"
features = ["serde"]
[dependencies.urlencoding]
version = "2.1.3"
[dependencies.zstd]
version = "0.13.3"
[dev-dependencies.assert_fs]
version = "1.1.3"
[dev-dependencies.clap]
version = "4.6"
features = ["derive"]
[dev-dependencies.criterion]
version = "0.8.2"
features = ["async_tokio"]
[dev-dependencies.fs_extra]
version = "1.3.0"
[dev-dependencies.icechunk-macros]
version = "2.0.2"
[dev-dependencies.noxious-client]
version = "1.0"
[dev-dependencies.port_check]
version = "0.3.0"
[dev-dependencies.pretty_assertions]
version = "1.4.1"
[dev-dependencies.proptest]
version = "1.11.0"
[dev-dependencies.proptest-state-machine]
version = "0.8.0"
[dev-dependencies.reqwest]
version = "0.13"
features = ["json"]
[dev-dependencies.rstest]
version = "0.26.1"
[dev-dependencies.rstest_reuse]
version = "0.7.0"
[dev-dependencies.tempfile]
version = "3.27.0"
[dev-dependencies.test-log]
version = "0.2.19"
features = [
"trace",
"color",
"unstable",
]
default-features = false
[dev-dependencies.test-strategy]
version = "0.4.5"
[dev-dependencies.tracing-chrome]
version = "0.7"
[dev-dependencies.tracing-samply]
version = "0.1.5"
[dev-dependencies.uuid]
version = "1.23"
features = ["v4"]
[dev-dependencies.warp]
version = "0.4.2"
features = ["server"]
[target.'cfg(not(target_family = "wasm"))'.dependencies.tokio]
version = "1.51.1"
features = [
"rt-multi-thread",
"macros",
"sync",
"time",
"io-util",
"rt",
]
[target.'cfg(target_family = "wasm")'.dependencies.tokio]
version = "1.51.1"
features = [
"rt",
"macros",
"sync",
"time",
"io-util",
]
[lints.clippy]
allow_attributes = "warn"
cargo_common_metadata = "warn"
clone_on_ref_ptr = "warn"
create_dir = "warn"
dbg_macro = "warn"
doc_markdown = "warn"
exit = "warn"
expect_used = "warn"
implicit_clone = "warn"
inefficient_to_string = "warn"
large_types_passed_by_value = "warn"
manual_let_else = "warn"
needless_pass_by_value = "warn"
panic = "warn"
semicolon_if_nothing_returned = "warn"
todo = "warn"
undocumented_unsafe_blocks = "warn"
unimplemented = "warn"
uninlined_format_args = "warn"
unused_result_ok = "warn"
unused_trait_names = "warn"
unwrap_used = "warn"
wildcard_dependencies = "warn"
[lints.rust]
bare_trait_objects = "warn"
elided_lifetimes_in_paths = "warn"
missing_debug_implementations = "warn"
trivial_numeric_casts = "warn"
unreachable_pub = "warn"
unsafe_code = "warn"
unused_qualifications = "warn"