diff --git a/zcash_primitives/src/merkle_tree.rs b/zcash_primitives/src/merkle_tree.rs index 2dcc5ccea..e48f8eec4 100644 --- a/zcash_primitives/src/merkle_tree.rs +++ b/zcash_primitives/src/merkle_tree.rs @@ -90,10 +90,10 @@ impl CommitmentTree { /// Returns the number of notes in the tree. pub fn size(&self) -> usize { self.parents.iter().enumerate().fold( - match (self.left.is_some(), self.right.is_some()) { - (false, false) => 0, - (true, false) | (false, true) => 1, - (true, true) => 2, + match (self.left, self.right) { + (None, None) => 0, + (Some(_), None) | (None, Some(_)) => 1, + (Some(_), Some(_)) => 2, }, |acc, (i, p)| { // Treat occupation of parents array as a binary number diff --git a/zcash_primitives/src/serialize.rs b/zcash_primitives/src/serialize.rs index 831231291..41778dcaf 100644 --- a/zcash_primitives/src/serialize.rs +++ b/zcash_primitives/src/serialize.rs @@ -221,6 +221,7 @@ mod tests { eval_u8!(Some(1), [1, 1]); eval_u8!(Some(5), [1, 5]); + eval_vec!(None as Option>, [0]); eval_vec!(Some(vec![]), [1, 0]); eval_vec!(Some(vec![0]), [1, 1, 0]); eval_vec!(Some(vec![1]), [1, 1, 1]);