| # Licensed to the Apache Software Foundation (ASF) under one |
| # or more contributor license agreements. See the NOTICE file |
| # distributed with this work for additional information |
| # regarding copyright ownership. The ASF licenses this file |
| # to you under the Apache License, Version 2.0 (the |
| # "License"); you may not use this file except in compliance |
| # with the License. You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, |
| # software distributed under the License is distributed on an |
| # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| # KIND, either express or implied. See the License for the |
| # specific language governing permissions and limitations |
| # under the License. |
| |
| [package] |
| name = "parquet" |
| version = "24.0.0" |
| license = "Apache-2.0" |
| description = "Apache Parquet implementation in Rust" |
| homepage = "https://github.com/apache/arrow-rs" |
| repository = "https://github.com/apache/arrow-rs" |
| authors = ["Apache Arrow <dev@arrow.apache.org>"] |
| keywords = ["arrow", "parquet", "hadoop"] |
| readme = "README.md" |
| build = "build.rs" |
| edition = "2021" |
| rust-version = "1.62" |
| |
| [dependencies] |
| ahash = "0.8" |
| bytes = { version = "1.1", default-features = false, features = ["std"] } |
| thrift = { version = "0.16", default-features = false } |
| snap = { version = "1.0", default-features = false, optional = true } |
| brotli = { version = "3.3", default-features = false, features = ["std"], optional = true } |
| flate2 = { version = "1.0", default-features = false, features = ["rust_backend"], optional = true } |
| lz4 = { version = "1.23", default-features = false, optional = true } |
| zstd = { version = "0.11.1", optional = true, default-features = false } |
| chrono = { version = "0.4", default-features = false, features = ["alloc"] } |
| num = { version = "0.4", default-features = false } |
| num-bigint = { version = "0.4", default-features = false } |
| arrow = { path = "../arrow", version = "24.0.0", optional = true, default-features = false, features = ["ipc"] } |
| base64 = { version = "0.13", default-features = false, features = ["std"], optional = true } |
| clap = { version = "3", default-features = false, features = ["std", "derive", "env"], optional = true } |
| serde_json = { version = "1.0", default-features = false, features = ["std"], optional = true } |
| seq-macro = { version = "0.3", default-features = false } |
| rand = { version = "0.8", default-features = false, features = ["std", "std_rng"] } |
| futures = { version = "0.3", default-features = false, features = ["std"], optional = true } |
| tokio = { version = "1.0", optional = true, default-features = false, features = ["macros", "fs", "rt", "io-util"] } |
| hashbrown = { version = "0.12", default-features = false } |
| |
| [dev-dependencies] |
| base64 = { version = "0.13", default-features = false, features = ["std"] } |
| criterion = { version = "0.4", default-features = false } |
| snap = { version = "1.0", default-features = false } |
| tempfile = { version = "3.0", default-features = false } |
| brotli = { version = "3.3", default-features = false, features = ["std"] } |
| flate2 = { version = "1.0", default-features = false, features = ["rust_backend"] } |
| lz4 = { version = "1.23", default-features = false } |
| zstd = { version = "0.11", default-features = false } |
| serde_json = { version = "1.0", features = ["std"], default-features = false } |
| arrow = { path = "../arrow", version = "24.0.0", default-features = false, features = ["ipc", "test_utils", "prettyprint", "json"] } |
| |
| [package.metadata.docs.rs] |
| all-features = true |
| |
| [features] |
| default = ["arrow", "snap", "brotli", "flate2", "lz4", "zstd", "base64"] |
| # Enable arrow reader/writer APIs |
| arrow = ["dep:arrow", "base64"] |
| # Enable CLI tools |
| cli = ["json", "base64", "clap", "arrow/csv"] |
| # Enable JSON APIs |
| json = ["serde_json", "base64"] |
| # Enable internal testing APIs |
| test_common = ["arrow/test_utils"] |
| # Experimental, unstable functionality primarily used for testing |
| experimental = [] |
| # Enable async APIs |
| async = ["futures", "tokio"] |
| |
| [[bin]] |
| name = "parquet-read" |
| required-features = ["cli"] |
| |
| [[bin]] |
| name = "parquet-schema" |
| required-features = ["cli"] |
| |
| [[bin]] |
| name = "parquet-rowcount" |
| required-features = ["cli"] |
| |
| [[bin]] |
| name = "parquet-fromcsv" |
| required-features = ["cli"] |
| |
| [[bench]] |
| name = "arrow_writer" |
| required-features = ["arrow"] |
| harness = false |
| |
| [[bench]] |
| name = "arrow_reader" |
| required-features = ["arrow", "test_common", "experimental"] |
| harness = false |
| |
| [lib] |
| bench = false |