|
|
@ -222,20 +222,21 @@ public final class DfsReader extends ObjectReader implements ObjectReuseAsIs { |
|
|
|
ObjectLoader ldr; |
|
|
|
ObjectLoader ldr; |
|
|
|
if (last != null) { |
|
|
|
if (last != null) { |
|
|
|
ldr = last.get(this, objectId); |
|
|
|
ldr = last.get(this, objectId); |
|
|
|
if (ldr != null) |
|
|
|
if (ldr != null) { |
|
|
|
return ldr; |
|
|
|
return checkType(ldr, objectId, typeHint); |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
PackList packList = db.getPackList(); |
|
|
|
PackList packList = db.getPackList(); |
|
|
|
boolean noGarbage = avoidUnreachable; |
|
|
|
boolean noGarbage = avoidUnreachable; |
|
|
|
ldr = openImpl(packList, objectId, noGarbage); |
|
|
|
ldr = openImpl(packList, objectId, noGarbage); |
|
|
|
if (ldr != null) { |
|
|
|
if (ldr != null) { |
|
|
|
return ldr; |
|
|
|
return checkType(ldr, objectId, typeHint); |
|
|
|
} |
|
|
|
} |
|
|
|
if (packList.dirty()) { |
|
|
|
if (packList.dirty()) { |
|
|
|
ldr = openImpl(db.scanPacks(packList), objectId, noGarbage); |
|
|
|
ldr = openImpl(db.scanPacks(packList), objectId, noGarbage); |
|
|
|
if (ldr != null) { |
|
|
|
if (ldr != null) { |
|
|
|
return ldr; |
|
|
|
return checkType(ldr, objectId, typeHint); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
@ -245,6 +246,14 @@ public final class DfsReader extends ObjectReader implements ObjectReuseAsIs { |
|
|
|
throw new MissingObjectException(objectId.copy(), typeHint); |
|
|
|
throw new MissingObjectException(objectId.copy(), typeHint); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private static ObjectLoader checkType(ObjectLoader ldr, AnyObjectId id, |
|
|
|
|
|
|
|
int typeHint) throws IncorrectObjectTypeException { |
|
|
|
|
|
|
|
if (typeHint != OBJ_ANY && ldr.getType() != typeHint) { |
|
|
|
|
|
|
|
throw new IncorrectObjectTypeException(id.copy(), typeHint); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
return ldr; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
private ObjectLoader openImpl(PackList packList, AnyObjectId objectId, |
|
|
|
private ObjectLoader openImpl(PackList packList, AnyObjectId objectId, |
|
|
|
boolean noGarbage) throws IOException { |
|
|
|
boolean noGarbage) throws IOException { |
|
|
|
for (DfsPackFile pack : packList.packs) { |
|
|
|
for (DfsPackFile pack : packList.packs) { |
|
|
|