summaryrefslogtreecommitdiffstats
path: root/org.eclipse.jgit
diff options
context:
space:
mode:
authorShawn O. Pearce <spearce@spearce.org>2010-04-16 16:37:29 -0700
committerShawn O. Pearce <spearce@spearce.org>2010-04-16 17:04:38 -0700
commita770205070b52199e5c561f407ee0b0168dd8b9f (patch)
tree63a13014a044b1023af48401d181f5e2b802c3d2 /org.eclipse.jgit
parent6029bb24adafd4434f362c58e2f00c0057502f45 (diff)
downloadjgit-a770205070b52199e5c561f407ee0b0168dd8b9f.tar.gz
jgit-a770205070b52199e5c561f407ee0b0168dd8b9f.zip
ReceivePack: Micro-optimize object lookup when checking connectivity
If we are checking the visibility of everything referenced in the pack that isn't already reachable by a reference, it needs to be in the provided set. Since the provided set lists everything that is in this pack, we can avoid checking to see if the blob exists on disk, because we know it should be there, it was found in the pack we just consumed. Change-Id: Ie3c7746f734d13077242100a68e048f1ac18c34a Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
Diffstat (limited to 'org.eclipse.jgit')
-rw-r--r--org.eclipse.jgit/src/org/eclipse/jgit/transport/ReceivePack.java10
1 files changed, 7 insertions, 3 deletions
diff --git a/org.eclipse.jgit/src/org/eclipse/jgit/transport/ReceivePack.java b/org.eclipse.jgit/src/org/eclipse/jgit/transport/ReceivePack.java
index 85522edc49..7c113d65f6 100644
--- a/org.eclipse.jgit/src/org/eclipse/jgit/transport/ReceivePack.java
+++ b/org.eclipse.jgit/src/org/eclipse/jgit/transport/ReceivePack.java
@@ -823,11 +823,15 @@ public class ReceivePack {
RevObject o;
while ((o = ow.nextObject()) != null) {
+ if (ensureObjectsProvidedVisible) {
+ if (providedObjects.contains(o))
+ continue;
+ else
+ throw new MissingObjectException(o, o.getType());
+ }
+
if (o instanceof RevBlob && !db.hasObject(o))
throw new MissingObjectException(o, Constants.TYPE_BLOB);
-
- if (ensureObjectsProvidedVisible && !providedObjects.contains(o))
- throw new MissingObjectException(o, o.getType());
}
}