public abstract class TreeFilter extends Object
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:
PathFilter
Difference filters:
ANY_DIFF
.Boolean modifiers:
AndTreeFilter
OrTreeFilter
NotTreeFilter
Modifier and Type | Field and Description |
---|---|
static TreeFilter |
ALL
Selects all tree entries.
|
static TreeFilter |
ANY_DIFF
Selects only tree entries which differ between at least 2 trees.
|
Constructor and Description |
---|
TreeFilter() |
Modifier and Type | Method and Description |
---|---|
abstract TreeFilter |
clone()
Clone this tree filter, including its parameters.
|
abstract boolean |
include(TreeWalk walker)
Determine if the current entry is interesting to report.
|
TreeFilter |
negate()
Create a new filter that does the opposite of this filter.
|
abstract boolean |
shouldBeRecursive()
Does this tree filter require a recursive walk to match everything?
|
String |
toString() |
public static final TreeFilter ALL
public static final TreeFilter ANY_DIFF
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
and DirCacheIterator
applications should use IndexDiffFilter
.
public TreeFilter negate()
public abstract boolean include(TreeWalk walker) throws MissingObjectException, IncorrectObjectTypeException, IOException
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.
walker
- the walker the filter needs to examine.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.public abstract boolean shouldBeRecursive()
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.
public abstract TreeFilter clone()
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.
Copyright © 2015 Eclipse JGit Project. All rights reserved.