Class TreeFilter
- Direct Known Subclasses:
AndTreeFilter
,FollowFilter
,IndexDiff.ProgressReportingFilter
,IndexDiffFilter
,InterIndexDiffFilter
,LfsPointerFilter
,NotIgnoredFilter
,NotTreeFilter
,OrTreeFilter
,PathFilter
,PathFilterGroup.Group
,PathFilterGroup.Single
,PathSuffixFilter
,SkipWorkTreeFilter
,TreeFilter.AllFilter
,TreeFilter.AnyDiffFilter
This is an abstract interface. Applications may implement a subclass, or use one of the predefined implementations already available within this package.
Unless specifically noted otherwise a TreeFilter implementation is not thread
safe and may not be shared by different TreeWalk instances at the same time.
This restriction allows TreeFilter implementations to cache state within
their instances during include(TreeWalk)
if it is beneficial to
their implementation. Deep clones created by clone()
may be used to
construct a thread-safe copy of an existing filter.
Path filters:
- Matching pathname:
PathFilter
Difference filters:
- Only select differences:
ANY_DIFF
.
Boolean modifiers:
- AND:
AndTreeFilter
- OR:
OrTreeFilter
- NOT:
NotTreeFilter
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionprivate static final class
private static final class
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final TreeFilter
Selects all tree entries.static final TreeFilter
Selects only tree entries which differ between at least 2 trees. -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionabstract TreeFilter
clone()
Clone this tree filter, including its parameters.abstract boolean
Determine if the current entry is interesting to report.int
matchFilter
(TreeWalk walker) Determine if the current entry is a parent, a match, or no match.negate()
Create a new filter that does the opposite of this filter.abstract boolean
Does this tree filter require a recursive walk to match everything?toString()
-
Field Details
-
ALL
Selects all tree entries. -
ANY_DIFF
Selects only tree entries which differ between at least 2 trees.This filter also prevents a TreeWalk from recursing into a subtree if all parent trees have the identical subtree at the same path. This dramatically improves walk performance as only the changed subtrees are entered into.
If this filter is applied to a walker with only one tree it behaves like
ALL
, or as though the walker was matching a virtual empty tree against the single tree it was actually given. Applications may wish to treat such a difference as "all names added".When comparing
WorkingTreeIterator
andDirCacheIterator
applications should useIndexDiffFilter
.
-
-
Constructor Details
-
TreeFilter
public TreeFilter()
-
-
Method Details
-
negate
Create a new filter that does the opposite of this filter.- Returns:
- a new filter that includes tree entries this filter rejects.
-
include
public abstract boolean include(TreeWalk walker) throws MissingObjectException, IncorrectObjectTypeException, IOException Determine if the current entry is interesting to report.This method is consulted for subtree entries even if
TreeWalk.isRecursive()
is enabled. The consultation allows the filter to bypass subtree recursion on a case-by-case basis, even when recursion is enabled at the application level.- Parameters:
walker
- the walker the filter needs to examine.- Returns:
- true if the current entry should be seen by the application; false to hide the entry.
- Throws:
MissingObjectException
- an object the filter needs to consult to determine its answer does not exist in the Git repository the walker is operating on. Filtering this current walker entry is impossible without the object.IncorrectObjectTypeException
- an object the filter needed to consult was not of the expected object type. This usually indicates a corrupt repository, as an object link is referencing the wrong type.IOException
- a loose object or pack file could not be read to obtain data necessary for the filter to make its decision.
-
matchFilter
public int matchFilter(TreeWalk walker) throws MissingObjectException, IncorrectObjectTypeException, IOException Determine if the current entry is a parent, a match, or no match.This method extends the result returned by
include(TreeWalk)
with a third option (-1), splitting the value true. This gives the application a possibility to distinguish between an exact match and the case when a subtree to the current entry might be a match.- Parameters:
walker
- the walker the filter needs to examine.- Returns:
- -1 if the current entry is a parent of the filter but no exact match has been made; 0 if the current entry should be seen by the application; 1 if it should be hidden.
- Throws:
MissingObjectException
- as thrown byinclude(TreeWalk)
IncorrectObjectTypeException
- as thrown byinclude(TreeWalk)
IOException
- as thrown byinclude(TreeWalk)
- Since:
- 4.7
-
shouldBeRecursive
public abstract boolean shouldBeRecursive()Does this tree filter require a recursive walk to match everything?If this tree filter is matching on full entry path names and its pattern is looking for a '/' then the filter would require a recursive TreeWalk to accurately make its decisions. The walker is not required to enable recursive behavior for any particular filter, this is only a hint.
- Returns:
- true if the filter would like to have the walker recurse into subtrees to make sure it matches everything correctly; false if the filter does not require entering subtrees.
-
clone
Clone this tree filter, including its parameters.This is a deep clone. If this filter embeds objects or other filters it must also clone those, to ensure the instances do not share mutable data.
-
toString
-