diff options
author | Terry Parker <tparker@google.com> | 2017-04-12 10:25:09 -0400 |
---|---|---|
committer | Gerrit Code Review @ Eclipse.org <gerrit@eclipse.org> | 2017-04-12 10:25:11 -0400 |
commit | 56a1cced74b7baf03c0db91af9b9f2e9f278a5ab (patch) | |
tree | a09000aa62c848e366b74db740d8ec96da6b1f14 /org.eclipse.jgit | |
parent | cc0dbbae435d4101a9253e2fc527fb2909278f17 (diff) | |
parent | f5368dc97f564cf5eac3e7e2742680bf2f95fc0b (diff) | |
download | jgit-56a1cced74b7baf03c0db91af9b9f2e9f278a5ab.tar.gz jgit-56a1cced74b7baf03c0db91af9b9f2e9f278a5ab.zip |
Merge "Only throw MissingObjectException when necessary"
Diffstat (limited to 'org.eclipse.jgit')
-rw-r--r-- | org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/PackWriterBitmapWalker.java | 49 |
1 files changed, 32 insertions, 17 deletions
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 2ec4d568c7..7e3e189be7 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 @@ -117,24 +117,39 @@ final class PackWriterBitmapWalker { new AddUnseenToBitmapFilter(seen, bitmapResult)); } - while (walker.next() != null) { - // Iterate through all of the commits. The BitmapRevFilter does - // the work. - // - // filter.include returns true for commits that do not have - // a bitmap in bitmapIndex and are not reachable from a - // bitmap in bitmapIndex encountered earlier in the walk. - // Thus the number of commits returned by next() measures how - // much history was traversed without being able to make use - // of bitmaps. - pm.update(1); - countOfBitmapIndexMisses++; - } + try { + while (walker.next() != null) { + // Iterate through all of the commits. The BitmapRevFilter does + // the work. + // + // filter.include returns true for commits that do not have + // a bitmap in bitmapIndex and are not reachable from a + // bitmap in bitmapIndex encountered earlier in the walk. + // Thus the number of commits returned by next() measures how + // much history was traversed without being able to make use + // of bitmaps. + pm.update(1); + countOfBitmapIndexMisses++; + } - RevObject ro; - while ((ro = walker.nextObject()) != null) { - bitmapResult.addObject(ro, ro.getType()); - pm.update(1); + RevObject ro; + while ((ro = walker.nextObject()) != null) { + bitmapResult.addObject(ro, ro.getType()); + pm.update(1); + } + } catch (MissingObjectException e) { + if (!ignoreMissingStart) { + throw e; + } + // Even when none of the objects we started the walk from is missing, + // an object reachable from one can be. RevWalk and ObjectWalk don't + // provide a way to ignore the missing object and continue, so bail + // out early with an undersized bitmap. + // + // The resulting packfile is likely to be much too large, but that's + // better than serving an error. + // + // TODO(czhen): Resume the walk instead once RevWalk supports that. } } |