summaryrefslogtreecommitdiffstats
path: root/org.eclipse.jgit
diff options
context:
space:
mode:
authorRobin Rosenberg <robin.rosenberg@dewire.com>2013-01-01 15:06:07 +0100
committerRobin Rosenberg <robin.rosenberg@dewire.com>2013-01-07 01:08:01 +0100
commit576e5acdd054e2dcd8cde3fe4d822bc3609850c1 (patch)
treea836ac788863545d1257ffbc2bee8e63afa09ff9 /org.eclipse.jgit
parent549034500a55ffc8f401fd73a74d8dc55f096d2f (diff)
downloadjgit-576e5acdd054e2dcd8cde3fe4d822bc3609850c1.tar.gz
jgit-576e5acdd054e2dcd8cde3fe4d822bc3609850c1.zip
Speed up PathFilterGroup.include for large set of paths
This requires that we internally sort all paths so content of directories follow the directory immediately. Bug: 397185 Change-Id: I3e9735c7bdd99437929da8f9c9d4960a1273054b
Diffstat (limited to 'org.eclipse.jgit')
-rw-r--r--org.eclipse.jgit/src/org/eclipse/jgit/treewalk/filter/PathFilterGroup.java70
1 files changed, 55 insertions, 15 deletions
diff --git a/org.eclipse.jgit/src/org/eclipse/jgit/treewalk/filter/PathFilterGroup.java b/org.eclipse.jgit/src/org/eclipse/jgit/treewalk/filter/PathFilterGroup.java
index 51761a8126..d4b0555cdb 100644
--- a/org.eclipse.jgit/src/org/eclipse/jgit/treewalk/filter/PathFilterGroup.java
+++ b/org.eclipse.jgit/src/org/eclipse/jgit/treewalk/filter/PathFilterGroup.java
@@ -177,33 +177,73 @@ public class PathFilterGroup {
}
static class Group extends TreeFilter {
- private static final Comparator<PathFilter> PATH_SORT = new Comparator<PathFilter>() {
+ private static int pathPrefixSortCompare(byte[] p1, byte[] p2,
+ boolean justMatch) {
+ int ci = 0;
+ while (ci < p1.length && ci < p2.length) {
+ int c1 = p1[ci];
+ int c2 = p2[ci];
+ if (c1 == '/')
+ c1 = 0;
+ if (c2 == '/')
+ c2 = 0;
+ int cmp = c1 - c2;
+ if (cmp != 0)
+ return cmp;
+ ++ci;
+ }
+ if (ci < p1.length) {
+ int c1 = p1[ci];
+ if (c1 == '/')
+ if (justMatch)
+ return 0;
+ return 1;
+ }
+ if (ci < p2.length) {
+ int c2 = p2[ci];
+ if (c2 == '/')
+ return 0;
+ return -1;
+ }
+ return 0;
+ }
+
+ private static final Comparator<PathFilter> PATH_PREFIX_SORT = new Comparator<PathFilter>() {
public int compare(final PathFilter o1, final PathFilter o2) {
- return o1.pathStr.compareTo(o2.pathStr);
+ return pathPrefixSortCompare(o1.pathRaw, o2.pathRaw, false);
}
+
};
private final PathFilter[] paths;
private Group(final PathFilter[] p) {
paths = p;
- Arrays.sort(paths, PATH_SORT);
+ Arrays.sort(paths, PATH_PREFIX_SORT);
}
@Override
public boolean include(final TreeWalk walker) {
- final int n = paths.length;
- for (int i = 0;;) {
- final byte[] r = paths[i].pathRaw;
- final int cmp = walker.isPathPrefix(r, r.length);
- if (cmp == 0)
- return true;
- if (++i < n)
- continue;
- if (cmp > 0)
- throw StopWalkException.INSTANCE;
- return false;
- }
+ final byte[] rawPath = walker.getRawPath();
+ Comparator comparator = new Comparator<Object>() {
+ public int compare(Object pf, Object raw) {
+ PathFilter pathFilter = (PathFilter) pf;
+ int ret = -pathPrefixSortCompare(walker.getRawPath(),
+ pathFilter.pathRaw, true);
+ return ret;
+ }
+ };
+
+ Object[] pathsObject = paths;
+ Object rawObject = rawPath;
+ @SuppressWarnings("unchecked")
+ int position = Arrays.binarySearch(pathsObject, rawObject,
+ comparator);
+ if (position >= 0)
+ return true;
+ if (position == -paths.length - 1)
+ throw StopWalkException.INSTANCE;
+ return false;
}
@Override