summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTerry Parker <tparker@google.com>2015-05-11 17:37:02 -0700
committerTerry Parker <tparker@google.com>2015-05-26 14:37:17 -0700
commit0e8ac496cd9bbfa3fa306ac45706f501fc24ac38 (patch)
tree83383dd68d1481384d7a17bbae7b1dfb3cede635
parent2ad2d85bcda42b5f2fde3c4126f07519e2c75c79 (diff)
downloadjgit-0e8ac496cd9bbfa3fa306ac45706f501fc24ac38.tar.gz
jgit-0e8ac496cd9bbfa3fa306ac45706f501fc24ac38.zip
Add bitmap index misses to PackWriter.Statistics
RevWalks to find commits that are not in bitmap indices are expensive. Track the count of commits that are enumerated via RevWalks as "bitmap index misses" in the PackWriter.Statistics class. Change-Id: Ie0135a0a0aeba2dfb6df78839d545006629f16cb Signed-off-by: Terry Parker <tparker@google.com>
-rw-r--r--org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/PackWriter.java13
-rw-r--r--org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/PackWriterBitmapWalker.java22
2 files changed, 32 insertions, 3 deletions
diff --git a/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/PackWriter.java b/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/PackWriter.java
index 8fac907270..adc6bf11ab 100644
--- a/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/PackWriter.java
+++ b/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/PackWriter.java
@@ -1591,6 +1591,7 @@ public class PackWriter implements AutoCloseable {
findObjectsToPackUsingBitmaps(bitmapWalker, want, have);
endPhase(countingMonitor);
stats.timeCounting = System.currentTimeMillis() - countingStart;
+ stats.bitmapIndexMisses = bitmapWalker.getCountOfBitmapIndexMisses();
return;
}
}
@@ -2084,6 +2085,8 @@ public class PackWriter implements AutoCloseable {
long totalObjects;
+ long bitmapIndexMisses;
+
long totalDeltas;
long reusedObjects;
@@ -2166,6 +2169,16 @@ public class PackWriter implements AutoCloseable {
}
/**
+ * @return the count of objects that needed to be discovered through an
+ * object walk because they were not found in bitmap indices.
+ *
+ * @since 4.0
+ */
+ public long getBitmapIndexMisses() {
+ return bitmapIndexMisses;
+ }
+
+ /**
* @return total number of deltas output. This may be lower than the
* actual number of deltas if a cached pack was reused.
*/
diff --git a/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/PackWriterBitmapWalker.java b/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/PackWriterBitmapWalker.java
index 63a91cd82d..debb2f2abc 100644
--- a/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/PackWriterBitmapWalker.java
+++ b/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/PackWriterBitmapWalker.java
@@ -71,6 +71,8 @@ final class PackWriterBitmapWalker {
private final ProgressMonitor pm;
+ private long countOfBitmapIndexMisses;
+
PackWriterBitmapWalker(
ObjectWalk walker, BitmapIndex bitmapIndex, ProgressMonitor pm) {
this.walker = walker;
@@ -78,6 +80,10 @@ final class PackWriterBitmapWalker {
this.pm = (pm == null) ? NullProgressMonitor.INSTANCE : pm;
}
+ long getCountOfBitmapIndexMisses() {
+ return countOfBitmapIndexMisses;
+ }
+
BitmapBuilder findObjects(Set<? extends ObjectId> start, BitmapBuilder seen, boolean ignoreMissingStart)
throws MissingObjectException, IncorrectObjectTypeException,
IOException {
@@ -104,7 +110,8 @@ final class PackWriterBitmapWalker {
}
if (marked) {
- walker.setRevFilter(newRevFilter(seen, bitmapResult));
+ BitmapRevFilter filter = newRevFilter(seen, bitmapResult);
+ walker.setRevFilter(filter);
while (walker.next() != null) {
// Iterate through all of the commits. The BitmapRevFilter does
@@ -117,6 +124,7 @@ final class PackWriterBitmapWalker {
bitmapResult.add(ro, ro.getType());
pm.update(1);
}
+ countOfBitmapIndexMisses += filter.getCountOfLoadedCommits();
}
return bitmapResult;
@@ -126,7 +134,7 @@ final class PackWriterBitmapWalker {
walker.reset();
}
- static RevFilter newRevFilter(
+ static BitmapRevFilter newRevFilter(
final BitmapBuilder seen, final BitmapBuilder bitmapResult) {
if (seen != null) {
return new BitmapRevFilter() {
@@ -146,12 +154,16 @@ final class PackWriterBitmapWalker {
}
static abstract class BitmapRevFilter extends RevFilter {
+ private long countOfLoadedCommits;
+
protected abstract boolean load(RevCommit cmit);
@Override
public final boolean include(RevWalk walker, RevCommit cmit) {
- if (load(cmit))
+ if (load(cmit)) {
+ countOfLoadedCommits++;
return true;
+ }
for (RevCommit p : cmit.getParents())
p.add(RevFlag.SEEN);
return false;
@@ -166,5 +178,9 @@ final class PackWriterBitmapWalker {
public final boolean requiresCommitBody() {
return false;
}
+
+ long getCountOfLoadedCommits() {
+ return countOfLoadedCommits;
+ }
}
}