Class LargePackedWholeObject
java.lang.Object
org.eclipse.jgit.lib.ObjectLoader
org.eclipse.jgit.internal.storage.file.LargePackedWholeObject
-
Nested Class Summary
Nested classes/interfaces inherited from class org.eclipse.jgit.lib.ObjectLoader
ObjectLoader.Filter, ObjectLoader.SmallObject -
Field Summary
FieldsModifier and TypeFieldDescriptionprivate final FileObjectDatabaseprivate final intprivate final longprivate final Packprivate final longprivate final int -
Constructor Summary
ConstructorsConstructorDescriptionLargePackedWholeObject(int type, long size, long objectOffset, int headerLength, Pack pack, FileObjectDatabase db) -
Method Summary
Modifier and TypeMethodDescriptionbyte[]Obtain a reference to the (possibly cached) bytes of this object.private ObjectIdlonggetSize()Get size of object in bytesintgetType()Get Git in pack object typebooleanisLarge()Whether this object is too large to obtain as a byte array.Obtain an input stream to read this object's data.Methods inherited from class org.eclipse.jgit.lib.ObjectLoader
copyTo, getBytes, getBytes, getCachedBytes
-
Field Details
-
type
private final int type -
size
private final long size -
objectOffset
private final long objectOffset -
headerLength
private final int headerLength -
pack
-
db
-
-
Constructor Details
-
LargePackedWholeObject
LargePackedWholeObject(int type, long size, long objectOffset, int headerLength, Pack pack, FileObjectDatabase db)
-
-
Method Details
-
getType
public int getType()Get Git in pack object type- Specified by:
getTypein classObjectLoader- Returns:
- Git in pack object type, see
Constants.
-
getSize
public long getSize()Get size of object in bytes- Specified by:
getSizein classObjectLoader- Returns:
- size of object in bytes
-
isLarge
public boolean isLarge()Whether this object is too large to obtain as a byte array.- Overrides:
isLargein classObjectLoader- Returns:
- true if this object is too large to obtain as a byte array.
Objects over a certain threshold should be accessed only by their
ObjectLoader.openStream()to prevent overflowing the JVM heap.
-
getCachedBytes
Obtain a reference to the (possibly cached) bytes of this object.This method offers direct access to the internal caches, potentially saving on data copies between the internal cache and higher level code. Callers who receive this reference must not modify its contents. Changes (if made) will affect the cache but not the repository itself.
- Specified by:
getCachedBytesin classObjectLoader- Returns:
- the cached bytes of this object. Do not modify it.
- Throws:
LargeObjectException- if the object won't fit into a byte array, becauseObjectLoader.isLarge()returns true. Callers should useObjectLoader.openStream()instead to access the contents.
-
openStream
Obtain an input stream to read this object's data.- Specified by:
openStreamin classObjectLoader- Returns:
- a stream of this object's data. Caller must close the stream when through with it. The returned stream is buffered with a reasonable buffer size.
- Throws:
MissingObjectException- the object no longer exists.IOException- the object store cannot be accessed.
-
getObjectId
- Throws:
IOException
-