Trait git_traverse::tree::Visit [−][src]
pub trait Visit { fn pop_front_tracked_path_and_set_current(&mut self); fn push_back_tracked_path_component(&mut self, component: &BStr); fn push_path_component(&mut self, component: &BStr); fn pop_path_component(&mut self); fn visit_tree(&mut self, entry: &Entry<'_>) -> Action; fn visit_nontree(&mut self, entry: &Entry<'_>) -> Action; }
Expand description
A trait to allow responding to a traversal designed to observe all entries in a tree, recursively while keeping track of paths if desired.
Required methods
fn pop_front_tracked_path_and_set_current(&mut self)
fn pop_front_tracked_path_and_set_current(&mut self)
Sets the full path path in front of the queue so future calls to push and pop components affect it instead.
fn push_back_tracked_path_component(&mut self, component: &BStr)
fn push_back_tracked_path_component(&mut self, component: &BStr)
Append a component
to the end of a path, which may be empty.
fn push_path_component(&mut self, component: &BStr)
fn push_path_component(&mut self, component: &BStr)
Append a component
to the end of a path, which may be empty.
fn pop_path_component(&mut self)
fn pop_path_component(&mut self)
Removes the last component from the path, which may leave it empty.
fn visit_tree(&mut self, entry: &Entry<'_>) -> Action
fn visit_tree(&mut self, entry: &Entry<'_>) -> Action
Observe a tree entry that is a tree and return an instruction whether to continue or not.
Action::Skip
can be used to prevent traversing it, for example if it’s known to the caller already.
The implementation may use the current path to learn where in the tree the change is located.
fn visit_nontree(&mut self, entry: &Entry<'_>) -> Action
fn visit_nontree(&mut self, entry: &Entry<'_>) -> Action
Observe a tree entry that is NO tree and return an instruction whether to continue or not.
Action::Skip
has no effect here.
The implementation may use the current path to learn where in the tree the change is located.