diff options
Diffstat (limited to 'vendor/gix-traverse/src')
-rw-r--r-- | vendor/gix-traverse/src/commit.rs | 81 | ||||
-rw-r--r-- | vendor/gix-traverse/src/tree/breadthfirst.rs | 53 |
2 files changed, 52 insertions, 82 deletions
diff --git a/vendor/gix-traverse/src/commit.rs b/vendor/gix-traverse/src/commit.rs index 29f5947b3..4bf49d2a0 100644 --- a/vendor/gix-traverse/src/commit.rs +++ b/vendor/gix-traverse/src/commit.rs @@ -1,8 +1,9 @@ +use gix_object::FindExt; use smallvec::SmallVec; /// An iterator over the ancestors one or more starting commits pub struct Ancestors<Find, Predicate, StateMut> { - find: Find, + objects: Find, cache: Option<gix_commitgraph::Graph>, predicate: Predicate, state: StateMut, @@ -95,7 +96,7 @@ pub mod ancestors { use gix_date::SecondsSinceUnixEpoch; use gix_hash::{oid, ObjectId}; use gix_hashtable::HashSet; - use gix_object::CommitRefIter; + use gix_object::{CommitRefIter, FindExt}; use smallvec::SmallVec; use crate::commit::{collect_parents, Ancestors, Either, Info, ParentIds, Parents, Sorting}; @@ -104,11 +105,8 @@ pub mod ancestors { #[derive(Debug, thiserror::Error)] #[allow(missing_docs)] pub enum Error { - #[error("The commit {oid} could not be found")] - FindExisting { - oid: ObjectId, - source: Box<dyn std::error::Error + Send + Sync + 'static>, - }, + #[error(transparent)] + Find(#[from] gix_object::find::existing_iter::Error), #[error(transparent)] ObjectDecode(#[from] gix_object::decode::Error), } @@ -147,11 +145,10 @@ pub mod ancestors { } /// Builder - impl<Find, Predicate, StateMut, E> Ancestors<Find, Predicate, StateMut> + impl<Find, Predicate, StateMut> Ancestors<Find, Predicate, StateMut> where - Find: for<'a> FnMut(&oid, &'a mut Vec<u8>) -> Result<CommitRefIter<'a>, E>, + Find: gix_object::Find, StateMut: BorrowMut<State>, - E: std::error::Error + Send + Sync + 'static, { /// Set the sorting method, either topological or by author date pub fn sorting(mut self, sorting: Sorting) -> Result<Self, Error> { @@ -164,11 +161,7 @@ pub mod ancestors { let cutoff_time = self.sorting.cutoff_time(); let state = self.state.borrow_mut(); for commit_id in state.next.drain(..) { - let commit_iter = - (self.find)(&commit_id, &mut state.buf).map_err(|err| Error::FindExisting { - oid: commit_id, - source: err.into(), - })?; + let commit_iter = self.objects.find_commit_iter(&commit_id, &mut state.buf)?; let time = commit_iter.committer()?.time.seconds; match cutoff_time { Some(cutoff_time) if time >= cutoff_time => { @@ -214,11 +207,10 @@ pub mod ancestors { } /// Initialization - impl<Find, StateMut, E> Ancestors<Find, fn(&oid) -> bool, StateMut> + impl<Find, StateMut> Ancestors<Find, fn(&oid) -> bool, StateMut> where - Find: for<'a> FnMut(&oid, &'a mut Vec<u8>) -> Result<CommitRefIter<'a>, E>, + Find: gix_object::Find, StateMut: BorrowMut<State>, - E: std::error::Error + Send + Sync + 'static, { /// Create a new instance. /// @@ -236,12 +228,11 @@ pub mod ancestors { } /// Initialization - impl<Find, Predicate, StateMut, E> Ancestors<Find, Predicate, StateMut> + impl<Find, Predicate, StateMut> Ancestors<Find, Predicate, StateMut> where - Find: for<'a> FnMut(&oid, &'a mut Vec<u8>) -> Result<CommitRefIter<'a>, E>, + Find: gix_object::Find, Predicate: FnMut(&oid) -> bool, StateMut: BorrowMut<State>, - E: std::error::Error + Send + Sync + 'static, { /// Create a new instance with commit filtering enabled. /// @@ -274,7 +265,7 @@ pub mod ancestors { } } Self { - find, + objects: find, cache: None, predicate, state, @@ -299,12 +290,11 @@ pub mod ancestors { } } - impl<Find, Predicate, StateMut, E> Iterator for Ancestors<Find, Predicate, StateMut> + impl<Find, Predicate, StateMut> Iterator for Ancestors<Find, Predicate, StateMut> where - Find: for<'a> FnMut(&oid, &'a mut Vec<u8>) -> Result<CommitRefIter<'a>, E>, + Find: gix_object::Find, Predicate: FnMut(&oid) -> bool, StateMut: BorrowMut<State>, - E: std::error::Error + Send + Sync + 'static, { type Item = Result<Info, Error>; @@ -334,12 +324,11 @@ pub mod ancestors { } /// Utilities - impl<Find, Predicate, StateMut, E> Ancestors<Find, Predicate, StateMut> + impl<Find, Predicate, StateMut> Ancestors<Find, Predicate, StateMut> where - Find: for<'a> FnMut(&oid, &'a mut Vec<u8>) -> Result<CommitRefIter<'a>, E>, + Find: gix_object::Find, Predicate: FnMut(&oid) -> bool, StateMut: BorrowMut<State>, - E: std::error::Error + Send + Sync + 'static, { fn next_by_commit_date( &mut self, @@ -349,7 +338,7 @@ pub mod ancestors { let (commit_time, oid) = state.queue.pop()?; let mut parents: ParentIds = Default::default(); - match super::find(self.cache.as_ref(), &mut self.find, &oid, &mut state.buf) { + match super::find(self.cache.as_ref(), &self.objects, &oid, &mut state.buf) { Ok(Either::CachedCommit(commit)) => { if !collect_parents(&mut state.parent_ids, self.cache.as_ref(), commit.iter_parents()) { // drop corrupt caches and try again with ODB @@ -380,7 +369,7 @@ pub mod ancestors { continue; } - let parent = (self.find)(id.as_ref(), &mut state.parents_buf).ok(); + let parent = self.objects.find_commit_iter(id.as_ref(), &mut state.parents_buf).ok(); let parent_commit_time = parent .and_then(|parent| parent.committer().ok().map(|committer| committer.time.seconds)) .unwrap_or_default(); @@ -395,12 +384,7 @@ pub mod ancestors { } } } - Err(err) => { - return Some(Err(Error::FindExisting { - oid, - source: err.into(), - })) - } + Err(err) => return Some(Err(err.into())), } Some(Ok(Info { id: oid, @@ -411,18 +395,17 @@ pub mod ancestors { } /// Utilities - impl<Find, Predicate, StateMut, E> Ancestors<Find, Predicate, StateMut> + impl<Find, Predicate, StateMut> Ancestors<Find, Predicate, StateMut> where - Find: for<'a> FnMut(&oid, &'a mut Vec<u8>) -> Result<CommitRefIter<'a>, E>, + Find: gix_object::Find, Predicate: FnMut(&oid) -> bool, StateMut: BorrowMut<State>, - E: std::error::Error + Send + Sync + 'static, { fn next_by_topology(&mut self) -> Option<Result<Info, Error>> { let state = self.state.borrow_mut(); let oid = state.next.pop_front()?; let mut parents: ParentIds = Default::default(); - match super::find(self.cache.as_ref(), &mut self.find, &oid, &mut state.buf) { + match super::find(self.cache.as_ref(), &self.objects, &oid, &mut state.buf) { Ok(Either::CachedCommit(commit)) => { if !collect_parents(&mut state.parent_ids, self.cache.as_ref(), commit.iter_parents()) { // drop corrupt caches and try again with ODB @@ -460,12 +443,7 @@ pub mod ancestors { } } } - Err(err) => { - return Some(Err(Error::FindExisting { - oid, - source: err.into(), - })) - } + Err(err) => return Some(Err(err.into())), } Some(Ok(Info { id: oid, @@ -503,18 +481,17 @@ fn collect_parents( true } -fn find<'cache, 'buf, Find, E>( +fn find<'cache, 'buf, Find>( cache: Option<&'cache gix_commitgraph::Graph>, - mut find: Find, + objects: Find, id: &gix_hash::oid, buf: &'buf mut Vec<u8>, -) -> Result<Either<'buf, 'cache>, E> +) -> Result<Either<'buf, 'cache>, gix_object::find::existing_iter::Error> where - Find: for<'a> FnMut(&gix_hash::oid, &'a mut Vec<u8>) -> Result<gix_object::CommitRefIter<'a>, E>, - E: std::error::Error + Send + Sync + 'static, + Find: gix_object::Find, { match cache.and_then(|cache| cache.commit_by_id(id).map(Either::CachedCommit)) { Some(c) => Ok(c), - None => find(id, buf).map(Either::CommitRefIter), + None => objects.find_commit_iter(id, buf).map(Either::CommitRefIter), } } diff --git a/vendor/gix-traverse/src/tree/breadthfirst.rs b/vendor/gix-traverse/src/tree/breadthfirst.rs index 115b9a396..bb5b3f7d2 100644 --- a/vendor/gix-traverse/src/tree/breadthfirst.rs +++ b/vendor/gix-traverse/src/tree/breadthfirst.rs @@ -6,8 +6,8 @@ use gix_hash::ObjectId; #[derive(Debug, thiserror::Error)] #[allow(missing_docs)] pub enum Error { - #[error("The tree {oid} could not be found")] - NotFound { oid: ObjectId }, + #[error(transparent)] + Find(#[from] gix_object::find::existing_iter::Error), #[error("The delegate cancelled the operation")] Cancelled, #[error(transparent)] @@ -31,8 +31,7 @@ impl State { pub(crate) mod impl_ { use std::borrow::BorrowMut; - use gix_hash::oid; - use gix_object::{tree::EntryMode, TreeRefIter}; + use gix_object::{FindExt, TreeRefIter}; use super::{Error, State}; use crate::tree::Visit; @@ -46,17 +45,17 @@ pub(crate) mod impl_ { /// * `find` - a way to lookup new object data during traversal by their `ObjectId`, writing their data into buffer and returning /// an iterator over entries if the object is present and is a tree. Caching should be implemented within this function /// as needed. The return value is `Option<TreeIter>` which degenerates all error information. Not finding a commit should also - /// be considered an errors as all objects in the tree DAG should be present in the database. Hence [`Error::NotFound`] should + /// be considered an errors as all objects in the tree DAG should be present in the database. Hence [`Error::Find`] should /// be escalated into a more specific error if its encountered by the caller. /// * `delegate` - A way to observe entries and control the iteration while allowing the optimizer to let you pay only for what you use. pub fn traverse<StateMut, Find, V>( root: TreeRefIter<'_>, mut state: StateMut, - mut find: Find, + objects: Find, delegate: &mut V, ) -> Result<(), Error> where - Find: for<'a> FnMut(&oid, &'a mut Vec<u8>) -> Option<TreeRefIter<'a>>, + Find: gix_object::Find, StateMut: BorrowMut<State>, V: Visit, { @@ -66,39 +65,33 @@ pub(crate) mod impl_ { loop { for entry in tree { let entry = entry?; - match entry.mode { - EntryMode::Tree => { - use crate::tree::visit::Action::*; - delegate.push_path_component(entry.filename); - let action = delegate.visit_tree(&entry); - match action { - Skip => {} - Continue => { - delegate.pop_path_component(); - delegate.push_back_tracked_path_component(entry.filename); - state.next.push_back(entry.oid.to_owned()) - } - Cancel => { - return Err(Error::Cancelled); - } + if entry.mode.is_tree() { + use crate::tree::visit::Action::*; + delegate.push_path_component(entry.filename); + let action = delegate.visit_tree(&entry); + match action { + Skip => {} + Continue => { + delegate.pop_path_component(); + delegate.push_back_tracked_path_component(entry.filename); + state.next.push_back(entry.oid.to_owned()) } - } - _non_tree => { - delegate.push_path_component(entry.filename); - if delegate.visit_nontree(&entry).cancelled() { + Cancel => { return Err(Error::Cancelled); } } + } else { + delegate.push_path_component(entry.filename); + if delegate.visit_nontree(&entry).cancelled() { + return Err(Error::Cancelled); + } } delegate.pop_path_component(); } match state.next.pop_front() { Some(oid) => { delegate.pop_front_tracked_path_and_set_current(); - match find(&oid, &mut state.buf) { - Some(tree_iter) => tree = tree_iter, - None => return Err(Error::NotFound { oid: oid.to_owned() }), - } + tree = objects.find_tree_iter(&oid, &mut state.buf)?; } None => break Ok(()), } |