Move common package and dependency configs into workspace config

The MSRV for the main crates is 1.65, which is higher than the Rust
version that stabilised workplace dependencies (1.64). The implicit MSRV
for the component crates is still lower than this, so we don't migrate
these crates.
This commit is contained in:
Jack Grigg 2023-09-26 20:12:23 +00:00
parent 1b7c49778d
commit 7e89300db9
10 changed files with 235 additions and 146 deletions

2
Cargo.lock generated
View File

@ -2968,12 +2968,10 @@ dependencies = [
"proptest", "proptest",
"prost", "prost",
"rand_core", "rand_core",
"rand_xorshift",
"rayon", "rayon",
"secrecy", "secrecy",
"shardtree", "shardtree",
"subtle", "subtle",
"tempfile",
"time", "time",
"tonic", "tonic",
"tonic-build", "tonic-build",

View File

@ -13,6 +13,97 @@ members = [
"zcash_proofs", "zcash_proofs",
] ]
[workspace.package]
edition = "2021"
rust-version = "1.65"
repository = "https://github.com/zcash/librustzcash"
license = "MIT OR Apache-2.0"
categories = ["cryptography::cryptocurrencies"]
# Common dependencies across all of our crates. Dependencies used only by a single crate
# (and that don't have cross-crate versioning needs) are specified by the crate itself.
#
# See the individual crate `Cargo.toml` files for information about which dependencies are
# part of a public API, and which can be updated without a SemVer bump.
[workspace.dependencies]
# Intra-workspace dependencies
equihash = { version = "0.2", path = "components/equihash" }
zcash_address = { version = "0.3", path = "components/zcash_address" }
zcash_client_backend = { version = "0.10", path = "zcash_client_backend" }
zcash_encoding = { version = "0.2", path = "components/zcash_encoding" }
zcash_note_encryption = "0.4"
zcash_primitives = { version = "0.13", path = "zcash_primitives", default-features = false }
zcash_proofs = { version = "0.13", path = "zcash_proofs", default-features = false }
# Shielded protocols
ff = "0.13"
group = "0.13"
incrementalmerkletree = "0.5"
shardtree = "0.1"
# Payment protocols
# - Sapling
bitvec = "1"
blake2s_simd = "1"
bls12_381 = "0.8"
jubjub = "0.10"
# - Orchard
nonempty = "0.7"
orchard = { version = "0.6", default-features = false }
# - Transparent
hdwallet = "0.4"
ripemd = "0.1"
secp256k1 = "0.26"
# CSPRNG
rand = "0.8"
rand_core = "0.6"
# Digests
blake2b_simd = "1"
sha2 = "0.10"
# Encodings
base64 = "0.21"
bech32 = "0.9"
bs58 = { version = "0.5", features = ["check"] }
byteorder = "1"
hex = "0.4"
percent-encoding = "2.1.0"
# Logging and metrics
memuse = "0.2.1"
tracing = "0.1"
# Parallel processing
crossbeam-channel = "0.5"
maybe-rayon = { version = "0.1.0", default-features = false }
rayon = "1.5"
# Protobuf and gRPC
prost = "0.12"
tonic = "0.10"
tonic-build = "0.10"
# Secret management
secrecy = "0.8"
subtle = "2.2.3"
# Static constants
lazy_static = "1"
# Tests and benchmarks
assert_matches = "1.5"
criterion = "0.4"
proptest = "1"
rand_xorshift = "0.3"
# ZIP 32
aes = "0.8"
fpe = "0.6"
[profile.release] [profile.release]
lto = true lto = true
panic = 'abort' panic = 'abort'

View File

@ -7,11 +7,12 @@ authors = [
"Kris Nuttycombe <kris@electriccoin.co>" "Kris Nuttycombe <kris@electriccoin.co>"
] ]
homepage = "https://github.com/zcash/librustzcash" homepage = "https://github.com/zcash/librustzcash"
repository = "https://github.com/zcash/librustzcash" repository.workspace = true
readme = "README.md" readme = "README.md"
license = "MIT OR Apache-2.0" license.workspace = true
edition = "2021" edition.workspace = true
rust-version = "1.65" rust-version.workspace = true
categories.workspace = true
# Exclude proto files so crates.io consumers don't need protoc. # Exclude proto files so crates.io consumers don't need protoc.
exclude = ["*.proto"] exclude = ["*.proto"]
@ -20,10 +21,10 @@ exclude = ["*.proto"]
development = ["zcash_proofs"] development = ["zcash_proofs"]
[dependencies] [dependencies]
zcash_address = { version = "0.3", path = "../components/zcash_address" } zcash_address.workspace = true
zcash_encoding = { version = "0.2", path = "../components/zcash_encoding" } zcash_encoding.workspace = true
zcash_note_encryption = "0.4" zcash_note_encryption.workspace = true
zcash_primitives = { version = "0.13", path = "../zcash_primitives", default-features = false } zcash_primitives.workspace = true
# Dependencies exposed in a public API: # Dependencies exposed in a public API:
# (Breaking upgrades to these require a breaking upgrade to this crate.) # (Breaking upgrades to these require a breaking upgrade to this crate.)
@ -31,37 +32,37 @@ zcash_primitives = { version = "0.13", path = "../zcash_primitives", default-fea
time = "0.3.22" time = "0.3.22"
# - Encodings # - Encodings
base64 = "0.21" base64.workspace = true
bech32 = "0.9" bech32.workspace = true
bs58 = { version = "0.5", features = ["check"] } bs58.workspace = true
# - Errors # - Errors
hdwallet = { version = "0.4", optional = true } hdwallet = { workspace = true, optional = true }
# - Logging and metrics # - Logging and metrics
memuse = "0.2" memuse.workspace = true
tracing = "0.1" tracing.workspace = true
# - Protobuf interfaces and gRPC bindings # - Protobuf interfaces and gRPC bindings
hex = "0.4" hex.workspace = true
prost = "0.12" prost.workspace = true
tonic = { version = "0.10", optional = true } tonic = { workspace = true, optional = true }
# - Secret management # - Secret management
secrecy = "0.8" secrecy.workspace = true
subtle = "2.2.3" subtle.workspace = true
# - Shielded protocols # - Shielded protocols
bls12_381 = "0.8" bls12_381.workspace = true
group = "0.13" group.workspace = true
orchard = { version = "0.6", default-features = false } orchard.workspace = true
# - Note commitment trees # - Note commitment trees
incrementalmerkletree = "0.5" incrementalmerkletree.workspace = true
shardtree = "0.1" shardtree.workspace = true
# - Test dependencies # - Test dependencies
proptest = { version = "1.0.0", optional = true } proptest = { workspace = true, optional = true }
# - ZIP 321 # - ZIP 321
nom = "7" nom = "7"
@ -69,27 +70,25 @@ nom = "7"
# Dependencies used internally: # Dependencies used internally:
# (Breaking upgrades to these are usually backwards-compatible, but check MSRVs.) # (Breaking upgrades to these are usually backwards-compatible, but check MSRVs.)
# - Encodings # - Encodings
byteorder = { version = "1", optional = true } byteorder = { workspace = true, optional = true }
percent-encoding = "2.1.0" percent-encoding.workspace = true
# - Scanning # - Scanning
crossbeam-channel = "0.5" crossbeam-channel.workspace = true
rayon = "1.5" rayon.workspace = true
[build-dependencies] [build-dependencies]
tonic-build = "0.10" tonic-build.workspace = true
which = "4" which = "4"
[dev-dependencies] [dev-dependencies]
assert_matches = "1.5" assert_matches.workspace = true
gumdrop = "0.8" gumdrop = "0.8"
jubjub = "0.10" jubjub.workspace = true
proptest = "1.0.0" proptest.workspace = true
rand_core = "0.6" rand_core.workspace = true
rand_xorshift = "0.3" zcash_proofs.workspace = true
tempfile = "3.5.0" zcash_address = { workspace = true, features = ["test-dependencies"] }
zcash_proofs = { version = "0.13", path = "../zcash_proofs", default-features = false }
zcash_address = { version = "0.3", path = "../components/zcash_address", features = ["test-dependencies"] }
time = ">=0.3.22, <0.3.24" # time 0.3.24 has MSRV 1.67 time = ">=0.3.22, <0.3.24" # time 0.3.24 has MSRV 1.67

View File

@ -127,7 +127,6 @@ where
/// ``` /// ```
/// # #[cfg(all(feature = "test-dependencies", feature = "local-prover"))] /// # #[cfg(all(feature = "test-dependencies", feature = "local-prover"))]
/// # { /// # {
/// use tempfile::NamedTempFile;
/// use zcash_primitives::{ /// use zcash_primitives::{
/// consensus::{self, Network}, /// consensus::{self, Network},
/// constants::testnet::COIN_TYPE, /// constants::testnet::COIN_TYPE,

View File

@ -7,38 +7,39 @@ authors = [
"Kris Nuttycombe <kris@electriccoin.co>" "Kris Nuttycombe <kris@electriccoin.co>"
] ]
homepage = "https://github.com/zcash/librustzcash" homepage = "https://github.com/zcash/librustzcash"
repository = "https://github.com/zcash/librustzcash" repository.workspace = true
readme = "README.md" readme = "README.md"
license = "MIT OR Apache-2.0" license.workspace = true
edition = "2021" edition.workspace = true
rust-version = "1.65" rust-version.workspace = true
categories.workspace = true
[dependencies] [dependencies]
zcash_client_backend = { version = "0.10", path = "../zcash_client_backend", features = ["unstable-serialization", "unstable-spanning-tree"]} zcash_client_backend = { workspace = true, features = ["unstable-serialization", "unstable-spanning-tree"] }
zcash_encoding = { version = "0.2", path = "../components/zcash_encoding" } zcash_encoding.workspace = true
zcash_primitives = { version = "0.13", path = "../zcash_primitives", default-features = false } zcash_primitives.workspace = true
# Dependencies exposed in a public API: # Dependencies exposed in a public API:
# (Breaking upgrades to these require a breaking upgrade to this crate.) # (Breaking upgrades to these require a breaking upgrade to this crate.)
# - Errors # - Errors
bs58 = { version = "0.5", features = ["check"] } bs58.workspace = true
hdwallet = { version = "0.4", optional = true } hdwallet = { workspace = true, optional = true }
# - Logging and metrics # - Logging and metrics
tracing = "0.1" tracing.workspace = true
# - Serialization # - Serialization
byteorder = "1" byteorder.workspace = true
prost = "0.12" prost.workspace = true
group = "0.13" group.workspace = true
jubjub = "0.10" jubjub.workspace = true
# - Secret management # - Secret management
secrecy = "0.8" secrecy.workspace = true
# - Note commitment trees # - Note commitment trees
incrementalmerkletree = "0.5" incrementalmerkletree.workspace = true
shardtree = { version = "0.1", features = ["legacy-api"] } shardtree = { workspace = true, features = ["legacy-api"] }
# - SQLite databases # - SQLite databases
rusqlite = { version = "0.29.0", features = ["bundled", "time", "array"] } rusqlite = { version = "0.29.0", features = ["bundled", "time", "array"] }
@ -49,21 +50,21 @@ uuid = "1.1"
# Dependencies used internally: # Dependencies used internally:
# (Breaking upgrades to these are usually backwards-compatible, but check MSRVs.) # (Breaking upgrades to these are usually backwards-compatible, but check MSRVs.)
maybe-rayon = {version = "0.1.0", default-features = false} maybe-rayon.workspace = true
[dev-dependencies] [dev-dependencies]
assert_matches = "1.5" assert_matches.workspace = true
incrementalmerkletree = { version = "0.5", features = ["test-dependencies"] } incrementalmerkletree = { workspace = true, features = ["test-dependencies"] }
shardtree = { version = "0.1", features = ["legacy-api", "test-dependencies"] } shardtree = { workspace = true, features = ["legacy-api", "test-dependencies"] }
proptest = "1.0.0" proptest.workspace = true
rand_core = "0.6" rand_core.workspace = true
regex = "1.4" regex = "1.4"
tempfile = "3.5.0" tempfile = "3.5.0"
zcash_note_encryption = "0.4" zcash_note_encryption.workspace = true
zcash_proofs = { version = "0.13", path = "../zcash_proofs" } zcash_proofs.workspace = true
zcash_primitives = { version = "0.13", path = "../zcash_primitives", features = ["test-dependencies"] } zcash_primitives = { workspace = true, features = ["test-dependencies"] }
zcash_client_backend = { version = "0.10", path = "../zcash_client_backend", features = ["test-dependencies", "unstable-serialization", "unstable-spanning-tree"] } zcash_client_backend = { workspace = true, features = ["test-dependencies", "unstable-serialization", "unstable-spanning-tree"] }
zcash_address = { version = "0.3", path = "../components/zcash_address", features = ["test-dependencies"] } zcash_address = { workspace = true, features = ["test-dependencies"] }
[features] [features]
default = ["multicore"] default = ["multicore"]

View File

@ -4,21 +4,22 @@ description = "Zcash Extension implementations & consensus node integration laye
version = "0.0.0" version = "0.0.0"
authors = ["Jack Grigg <jack@z.cash>", "Kris Nuttycombe <kris@z.cash>"] authors = ["Jack Grigg <jack@z.cash>", "Kris Nuttycombe <kris@z.cash>"]
homepage = "https://github.com/zcash/librustzcash" homepage = "https://github.com/zcash/librustzcash"
repository = "https://github.com/zcash/librustzcash" repository.workspace = true
license = "MIT OR Apache-2.0" license.workspace = true
edition = "2021" edition.workspace = true
rust-version = "1.65" rust-version.workspace = true
categories.workspace = true
[dependencies] [dependencies]
blake2b_simd = "1" blake2b_simd.workspace = true
zcash_primitives = { version = "0.13", path = "../zcash_primitives", default-features = false, features = ["zfuture" ] } zcash_primitives = { workspace = true, features = ["zfuture" ] }
[dev-dependencies] [dev-dependencies]
ff = "0.13" ff.workspace = true
jubjub = "0.10" jubjub.workspace = true
rand_core = "0.6" rand_core.workspace = true
zcash_address = { version = "0.3", path = "../components/zcash_address" } zcash_address.workspace = true
zcash_proofs = { version = "0.13", path = "../zcash_proofs" } zcash_proofs.workspace = true
[features] [features]
transparent-inputs = [] transparent-inputs = []

View File

@ -2,22 +2,22 @@
name = "zcash_history" name = "zcash_history"
version = "0.3.0" version = "0.3.0"
authors = ["NikVolf <nikvolf@gmail.com>"] authors = ["NikVolf <nikvolf@gmail.com>"]
edition = "2021" edition.workspace = true
rust-version = "1.65" rust-version.workspace = true
license = "MIT/Apache-2.0" repository.workspace = true
documentation = "https://docs.rs/zcash_history/" license.workspace = true
description = "Library for Zcash blockchain history tools" description = "Library for Zcash blockchain history tools"
categories = ["cryptography::cryptocurrencies"] categories.workspace = true
[dev-dependencies] [dev-dependencies]
assert_matches = "1.3.0" assert_matches.workspace = true
proptest = "1.0.0" proptest.workspace = true
[dependencies] [dependencies]
primitive-types = { version = "0.12", default-features = false } primitive-types = { version = "0.12", default-features = false }
byteorder = "1" byteorder.workspace = true
blake2 = { package = "blake2b_simd", version = "1" } blake2b_simd.workspace = true
proptest = { version = "1.0.0", optional = true } proptest = { workspace = true, optional = true }
[features] [features]
test-dependencies = ["proptest"] test-dependencies = ["proptest"]

View File

@ -1,7 +1,7 @@
use std::fmt; use std::fmt;
use std::io; use std::io;
use blake2::Params as Blake2Params; use blake2b_simd::Params as Blake2Params;
use byteorder::{ByteOrder, LittleEndian}; use byteorder::{ByteOrder, LittleEndian};
use crate::{node_data, NodeData, MAX_NODE_DATA_SIZE}; use crate::{node_data, NodeData, MAX_NODE_DATA_SIZE};

View File

@ -7,59 +7,59 @@ authors = [
"Kris Nuttycombe <kris@electriccoin.co>" "Kris Nuttycombe <kris@electriccoin.co>"
] ]
homepage = "https://github.com/zcash/librustzcash" homepage = "https://github.com/zcash/librustzcash"
repository = "https://github.com/zcash/librustzcash" repository.workspace = true
readme = "README.md" readme = "README.md"
license = "MIT OR Apache-2.0" license.workspace = true
edition = "2021" edition.workspace = true
rust-version = "1.65" rust-version.workspace = true
categories = ["cryptography::cryptocurrencies"] categories.workspace = true
[package.metadata.docs.rs] [package.metadata.docs.rs]
all-features = true all-features = true
[dependencies] [dependencies]
equihash = { version = "0.2", path = "../components/equihash" } equihash.workspace = true
zcash_address = { version = "0.3", path = "../components/zcash_address" } zcash_address.workspace = true
zcash_encoding = { version = "0.2", path = "../components/zcash_encoding" } zcash_encoding.workspace = true
# Dependencies exposed in a public API: # Dependencies exposed in a public API:
# (Breaking upgrades to these require a breaking upgrade to this crate.) # (Breaking upgrades to these require a breaking upgrade to this crate.)
# - CSPRNG # - CSPRNG
rand = "0.8" rand.workspace = true
rand_core = "0.6" rand_core.workspace = true
# - Digests (output types exposed) # - Digests (output types exposed)
blake2b_simd = "1" blake2b_simd.workspace = true
sha2 = "0.10" sha2.workspace = true
# - Metrics # - Metrics
memuse = "0.2.1" memuse.workspace = true
# - Secret management # - Secret management
subtle = "2.2.3" subtle.workspace = true
# - Shielded protocols # - Shielded protocols
bls12_381 = "0.8" bls12_381.workspace = true
ff = "0.13" ff.workspace = true
group = { version = "0.13", features = ["wnaf-memuse"] } group = { workspace = true, features = ["wnaf-memuse"] }
jubjub = "0.10" jubjub.workspace = true
nonempty = "0.7" nonempty.workspace = true
orchard = { version = "0.6", default-features = false } orchard.workspace = true
# - Note Commitment Trees # - Note Commitment Trees
incrementalmerkletree = { version = "0.5", features = ["legacy-api"] } incrementalmerkletree = { workspace = true, features = ["legacy-api"] }
# - Static constants # - Static constants
lazy_static = "1" lazy_static.workspace = true
# - Test dependencies # - Test dependencies
proptest = { version = "1.0.0", optional = true } proptest = { workspace = true, optional = true }
# - Transparent inputs # - Transparent inputs
# - `Error` type exposed # - `Error` type exposed
hdwallet = { version = "0.4", optional = true } hdwallet = { workspace = true, optional = true }
# - `SecretKey` and `PublicKey` types exposed # - `SecretKey` and `PublicKey` types exposed
secp256k1 = { version = "0.26", optional = true } secp256k1 = { workspace = true, optional = true }
# - ZIP 339 # - ZIP 339
bip0039 = { version = "0.10", features = ["std", "all-languages"] } bip0039 = { version = "0.10", features = ["std", "all-languages"] }
@ -67,32 +67,32 @@ bip0039 = { version = "0.10", features = ["std", "all-languages"] }
# Dependencies used internally: # Dependencies used internally:
# (Breaking upgrades to these are usually backwards-compatible, but check MSRVs.) # (Breaking upgrades to these are usually backwards-compatible, but check MSRVs.)
# - Encodings # - Encodings
byteorder = "1" byteorder.workspace = true
hex = "0.4" hex.workspace = true
# - Shielded protocols # - Shielded protocols
bitvec = "1" bitvec.workspace = true
blake2s_simd = "1" blake2s_simd.workspace = true
# - Transparent inputs # - Transparent inputs
ripemd = { version = "0.1", optional = true } ripemd = { workspace = true, optional = true }
# - ZIP 32 # - ZIP 32
aes = "0.8" aes.workspace = true
fpe = "0.6" fpe.workspace = true
[dependencies.zcash_note_encryption] [dependencies.zcash_note_encryption]
version = "0.4" workspace = true
features = ["pre-zip-212"] features = ["pre-zip-212"]
[dev-dependencies] [dev-dependencies]
chacha20poly1305 = "0.10" chacha20poly1305 = "0.10"
criterion = "0.4" criterion.workspace = true
incrementalmerkletree = { version = "0.5", features = ["legacy-api", "test-dependencies"] } incrementalmerkletree = { workspace = true, features = ["legacy-api", "test-dependencies"] }
proptest = "1.0.0" proptest.workspace = true
assert_matches = "1.3.0" assert_matches.workspace = true
rand_xorshift = "0.3" rand_xorshift.workspace = true
orchard = { version = "0.6", default-features = false, features = ["test-dependencies"] } orchard = { workspace = true, features = ["test-dependencies"] }
[target.'cfg(unix)'.dev-dependencies] [target.'cfg(unix)'.dev-dependencies]
pprof = { version = "0.11", features = ["criterion", "flamegraph"] } # MSRV 1.56 pprof = { version = "0.11", features = ["criterion", "flamegraph"] } # MSRV 1.56

View File

@ -6,33 +6,33 @@ authors = [
"Jack Grigg <jack@z.cash>", "Jack Grigg <jack@z.cash>",
] ]
homepage = "https://github.com/zcash/librustzcash" homepage = "https://github.com/zcash/librustzcash"
repository = "https://github.com/zcash/librustzcash" repository.workspace = true
readme = "README.md" readme = "README.md"
license = "MIT OR Apache-2.0" license.workspace = true
edition = "2021" edition.workspace = true
rust-version = "1.65" rust-version.workspace = true
categories = ["cryptography::cryptocurrencies"] categories.workspace = true
[package.metadata.docs.rs] [package.metadata.docs.rs]
all-features = true all-features = true
[dependencies] [dependencies]
zcash_primitives = { version = "0.13", path = "../zcash_primitives", default-features = false } zcash_primitives.workspace = true
# Dependencies exposed in a public API: # Dependencies exposed in a public API:
# (Breaking upgrades to these require a breaking upgrade to this crate.) # (Breaking upgrades to these require a breaking upgrade to this crate.)
bellman = { version = "0.14", default-features = false, features = ["groth16"] } bellman = { version = "0.14", default-features = false, features = ["groth16"] }
bls12_381 = "0.8" bls12_381.workspace = true
group = "0.13" group.workspace = true
jubjub = "0.10" jubjub.workspace = true
lazy_static = "1" lazy_static.workspace = true
minreq = { version = "2", features = ["https"], optional = true } minreq = { version = "2", features = ["https"], optional = true }
rand_core = "0.6" rand_core.workspace = true
tracing = "0.1" tracing.workspace = true
# Dependencies used internally: # Dependencies used internally:
# (Breaking upgrades to these are usually backwards-compatible, but check MSRVs.) # (Breaking upgrades to these are usually backwards-compatible, but check MSRVs.)
blake2b_simd = "1" blake2b_simd.workspace = true
home = { version = "0.5", optional = true } home = { version = "0.5", optional = true }
known-folders = { version = "1", optional = true } known-folders = { version = "1", optional = true }
redjubjub = "0.7" redjubjub = "0.7"
@ -40,9 +40,9 @@ wagyu-zcash-parameters = { version = "0.2", optional = true }
xdg = { version = "2.5", optional = true } xdg = { version = "2.5", optional = true }
[dev-dependencies] [dev-dependencies]
byteorder = "1" byteorder.workspace = true
criterion = "0.4" criterion.workspace = true
rand_xorshift = "0.3" rand_xorshift.workspace = true
[target.'cfg(unix)'.dev-dependencies] [target.'cfg(unix)'.dev-dependencies]
pprof = { version = "0.11", features = ["criterion", "flamegraph"] } # MSRV 1.56 pprof = { version = "0.11", features = ["criterion", "flamegraph"] } # MSRV 1.56