icechunk 2.0.2

Transactional storage engine for Zarr designed for use on cloud object storage
Documentation
# THIS FILE IS AUTOMATICALLY GENERATED BY CARGO
#
# When uploading crates to the registry Cargo will automatically
# "normalize" Cargo.toml files for maximal compatibility
# with all versions of Cargo and also rewrite `path` dependencies
# to registry (e.g., crates.io) dependencies.
#
# If you are reading this file be aware that the original Cargo.toml
# will likely look very different (and much more reasonable).
# See Cargo.toml.orig for the original contents.

[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"