From c34b2328c085a9f7b39236be080cf24248014b36 Mon Sep 17 00:00:00 2001 From: Ilya Grigoriev Date: Mon, 2 Jan 2023 16:24:00 -0800 Subject: [PATCH] `Index`: Expose an iterator over all entries Importantly, this includes the commits that are not visible and thus not in the `all()` revset. --- lib/src/index.rs | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/lib/src/index.rs b/lib/src/index.rs index f1c42a52e..3d9768714 100644 --- a/lib/src/index.rs +++ b/lib/src/index.rs @@ -127,6 +127,10 @@ impl<'a> IndexRef<'a> { } } + pub fn iter(&self) -> impl Iterator> + '_ { + (0..self.num_commits()).map(|pos| self.entry_by_pos(IndexPosition(pos))) + } + pub fn walk_revs(&self, wanted: &[CommitId], unwanted: &[CommitId]) -> RevWalk<'a> { match self { IndexRef::Readonly(index) => index.walk_revs(wanted, unwanted), @@ -1652,6 +1656,7 @@ mod tests { assert!(index.entry_by_id(&CommitId::from_hex("000000")).is_none()); assert!(index.entry_by_id(&CommitId::from_hex("aaa111")).is_none()); assert!(index.entry_by_id(&CommitId::from_hex("ffffff")).is_none()); + assert_eq!(index.iter().collect_vec(), vec![]); } #[test_case(false; "memory")] @@ -1768,6 +1773,17 @@ mod tests { let entry_3 = index.entry_by_id(&id_3).unwrap(); let entry_4 = index.entry_by_id(&id_4).unwrap(); let entry_5 = index.entry_by_id(&id_5).unwrap(); + assert_eq!( + index.iter().collect_vec(), + vec![ + entry_0.clone(), + entry_1.clone(), + entry_2.clone(), + entry_3.clone(), + entry_4.clone(), + entry_5.clone(), + ] + ); // Check properties of some entries assert_eq!(entry_0.pos, IndexPosition(0)); assert_eq!(entry_0.commit_id(), id_0); @@ -1847,6 +1863,7 @@ mod tests { // Stats are as expected let stats = index.stats(); assert_eq!(stats.num_commits, 7); + assert_eq!(index.iter().collect_vec().len(), 7); assert_eq!(stats.num_heads, 1); assert_eq!(stats.max_generation_number, 2); assert_eq!(stats.num_merges, 1);