Skip to content

Commit

Permalink
Document the consensus rules for note commitment trees (#3319)
Browse files Browse the repository at this point in the history
Co-authored-by: teor <[email protected]>
Co-authored-by: mergify[bot] <37929162+mergify[bot]@users.noreply.github.com>
  • Loading branch information
3 people authored Jan 14, 2022
1 parent e9c2125 commit ece2d0f
Show file tree
Hide file tree
Showing 3 changed files with 29 additions and 0 deletions.
10 changes: 10 additions & 0 deletions zebra-chain/src/orchard/tree.rs
Original file line number Diff line number Diff line change
Expand Up @@ -221,7 +221,17 @@ pub struct NoteCommitmentTree {
/// It consists of nodes along the rightmost (newer) branch of the tree that
/// has non-empty nodes. Upper (near root) empty nodes of the branch are not
/// stored.
///
/// # Consensus
///
/// > [NU5 onward] A block MUST NOT add Orchard note commitments that would result in the Orchard note
/// > commitment tree exceeding its capacity of 2^(MerkleDepth^Orchard) leaf nodes.
///
/// <https://zips.z.cash/protocol/protocol.pdf#merkletree>
///
/// Note: MerkleDepth^Orchard = MERKLE_DEPTH = 32.
inner: bridgetree::Frontier<Node, { MERKLE_DEPTH as u8 }>,

/// A cached root of the tree.
///
/// Every time the root is computed by [`Self::root`] it is cached here,
Expand Down
10 changes: 10 additions & 0 deletions zebra-chain/src/sapling/tree.rs
Original file line number Diff line number Diff line change
Expand Up @@ -184,7 +184,17 @@ pub struct NoteCommitmentTree {
/// It consists of nodes along the rightmost (newer) branch of the tree that
/// has non-empty nodes. Upper (near root) empty nodes of the branch are not
/// stored.
///
/// # Consensus
///
/// > [Sapling onward] A block MUST NOT add Sapling note commitments that would result in the Sapling note
/// > commitment tree exceeding its capacity of 2^(MerkleDepth^Sapling) leaf nodes.
///
/// <https://zips.z.cash/protocol/protocol.pdf#merkletree>
///
/// Note: MerkleDepth^Sapling = MERKLE_DEPTH = 32.
inner: bridgetree::Frontier<Node, { MERKLE_DEPTH as u8 }>,

/// A cached root of the tree.
///
/// Every time the root is computed by [`Self::root`] it is cached here,
Expand Down
9 changes: 9 additions & 0 deletions zebra-chain/src/sprout/tree.rs
Original file line number Diff line number Diff line change
Expand Up @@ -209,6 +209,15 @@ pub struct NoteCommitmentTree {
/// consists of nodes along the rightmost (newer) branch of the tree that
/// has non-empty nodes. Upper (near root) empty nodes of the branch are not
/// stored.
///
/// # Consensus
///
/// > A block MUST NOT add Sprout note commitments that would result in the Sprout note commitment tree
/// > exceeding its capacity of 2^(MerkleDepth^Sprout) leaf nodes.
///
/// <https://zips.z.cash/protocol/protocol.pdf#merkletree>
///
/// Note: MerkleDepth^Sprout = MERKLE_DEPTH = 29.
inner: bridgetree::Frontier<Node, { MERKLE_DEPTH as u8 }>,

/// A cached root of the tree.
Expand Down

0 comments on commit ece2d0f

Please sign in to comment.