Document feature flags

This commit is contained in:
Jack Grigg 2024-01-03 18:14:06 +00:00
parent 71711b9e4b
commit 314930e92d
8 changed files with 41 additions and 2 deletions

16
Cargo.lock generated
View File

@ -459,6 +459,15 @@ dependencies = [
"uuid", "uuid",
] ]
[[package]]
name = "document-features"
version = "0.2.8"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "ef5282ad69563b5fc40319526ba27e0e7363d552a896f0297d54f767717f9b95"
dependencies = [
"litrs",
]
[[package]] [[package]]
name = "either" name = "either"
version = "1.9.0" version = "1.9.0"
@ -744,6 +753,12 @@ version = "0.4.12"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "c4cd1a83af159aa67994778be9070f0ae1bd732942279cabb14f86f986a21456" checksum = "c4cd1a83af159aa67994778be9070f0ae1bd732942279cabb14f86f986a21456"
[[package]]
name = "litrs"
version = "0.4.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "b4ce301924b7887e9d637144fdade93f9dfff9b60981d4ac161db09720d39aa5"
[[package]] [[package]]
name = "lock_api" name = "lock_api"
version = "0.4.11" version = "0.4.11"
@ -1267,6 +1282,7 @@ dependencies = [
"byteorder", "byteorder",
"chacha20poly1305", "chacha20poly1305",
"criterion", "criterion",
"document-features",
"ff", "ff",
"fpe", "fpe",
"group", "group",

View File

@ -13,6 +13,10 @@ homepage = "https://github.com/zcash/sapling-crypto"
repository = "https://github.com/zcash/sapling-crypto" repository = "https://github.com/zcash/sapling-crypto"
license = "MIT OR Apache-2.0" license = "MIT OR Apache-2.0"
[package.metadata.docs.rs]
features = ["test-dependencies"]
rustdoc-args = ["--cfg", "docsrs"]
[dependencies] [dependencies]
ff = "0.13" ff = "0.13"
group = { version = "0.13", features = ["wnaf-memuse"] } group = { version = "0.13", features = ["wnaf-memuse"] }
@ -33,6 +37,9 @@ rand_core = "0.6"
blake2b_simd = "1" blake2b_simd = "1"
blake2s_simd = "1" blake2s_simd = "1"
# Documentation
document-features = "0.2"
# Encodings # Encodings
byteorder = "1" byteorder = "1"
hex = "0.4" hex = "0.4"
@ -73,11 +80,17 @@ rand_xorshift = "0.3"
pprof = { version = "0.11", features = ["criterion", "flamegraph"] } # MSRV 1.56 pprof = { version = "0.11", features = ["criterion", "flamegraph"] } # MSRV 1.56
[features] [features]
## Enables multithreading support for creating proofs.
multicore = ["bellman/multicore"] multicore = ["bellman/multicore"]
### A temporary feature flag that exposes granular APIs needed by `zcashd`. These APIs
### should not be relied upon and will be removed in a future release.
temporary-zcashd = [] temporary-zcashd = []
## Exposes APIs that are useful for testing, such as `proptest` strategies.
test-dependencies = [ test-dependencies = [
"incrementalmerkletree/test-dependencies", "incrementalmerkletree/test-dependencies",
"proptest", "dep:proptest",
] ]
[[bench]] [[bench]]

View File

@ -1065,7 +1065,7 @@ impl<V> Bundle<InProgress<Proven, PartiallyAuthorized>, V> {
} }
#[cfg(any(test, feature = "test-dependencies"))] #[cfg(any(test, feature = "test-dependencies"))]
pub mod testing { pub(crate) mod testing {
use std::fmt; use std::fmt;
use proptest::collection::vec; use proptest::collection::vec;

View File

@ -483,6 +483,7 @@ impl<A> From<OutputDescription<A>> for CompactOutputDescription {
} }
#[cfg(any(test, feature = "test-dependencies"))] #[cfg(any(test, feature = "test-dependencies"))]
#[cfg_attr(docsrs, doc(cfg(feature = "test-dependencies")))]
pub mod testing { pub mod testing {
use std::fmt; use std::fmt;

View File

@ -662,6 +662,7 @@ impl SharedSecret {
} }
#[cfg(any(test, feature = "test-dependencies"))] #[cfg(any(test, feature = "test-dependencies"))]
#[cfg_attr(docsrs, doc(cfg(feature = "test-dependencies")))]
pub mod testing { pub mod testing {
use proptest::collection::vec; use proptest::collection::vec;
use proptest::prelude::*; use proptest::prelude::*;

View File

@ -6,7 +6,12 @@
//! Sapling-specific types. For example, [`PaymentAddress`] is documented as being a //! Sapling-specific types. For example, [`PaymentAddress`] is documented as being a
//! shielded payment address; we implicitly mean it is an Sapling payment address (as //! shielded payment address; we implicitly mean it is an Sapling payment address (as
//! opposed to e.g. an Orchard payment address, which is also shielded). //! opposed to e.g. an Orchard payment address, which is also shielded).
//!
//! ## Feature flags
#![doc = document_features::document_features!()]
//!
#![cfg_attr(docsrs, feature(doc_cfg))]
// Catch documentation errors caused by code changes. // Catch documentation errors caused by code changes.
#![deny(rustdoc::broken_intra_doc_links)] #![deny(rustdoc::broken_intra_doc_links)]
#![deny(unsafe_code)] #![deny(unsafe_code)]
@ -40,6 +45,7 @@ pub use tree::{
pub use verifier::{BatchValidator, SaplingVerificationContext}; pub use verifier::{BatchValidator, SaplingVerificationContext};
#[cfg(any(test, feature = "test-dependencies"))] #[cfg(any(test, feature = "test-dependencies"))]
#[cfg_attr(docsrs, doc(cfg(feature = "test-dependencies")))]
pub mod testing { pub mod testing {
pub use super::{ pub use super::{
address::testing::arb_payment_address, keys::testing::arb_incoming_viewing_key, address::testing::arb_payment_address, keys::testing::arb_incoming_viewing_key,

View File

@ -171,6 +171,7 @@ impl OutputProver for OutputParameters {
} }
#[cfg(any(test, feature = "test-dependencies"))] #[cfg(any(test, feature = "test-dependencies"))]
#[cfg_attr(docsrs, doc(cfg(feature = "test-dependencies")))]
pub mod mock { pub mod mock {
use ff::Field; use ff::Field;

View File

@ -1718,6 +1718,7 @@ mod tests {
} }
#[cfg(any(test, feature = "test-dependencies"))] #[cfg(any(test, feature = "test-dependencies"))]
#[cfg_attr(docsrs, doc(cfg(feature = "test-dependencies")))]
pub mod testing { pub mod testing {
use proptest::collection::vec; use proptest::collection::vec;
use proptest::prelude::{any, prop_compose}; use proptest::prelude::{any, prop_compose};