Class GitIdentifiers
- java.lang.Object
-
- org.apache.commons.codec.digest.GitIdentifiers
-
public class GitIdentifiers extends java.lang.Object
Computes Git object identifiers and their generalizations described by the SWHID specification.When the hash algorithm is SHA-1, the identifiers produced by this class are identical to those used by Git. Other hash algorithms produce generalized identifiers as described by the SWHID specification.
This class is immutable and thread-safe. However, the
MessageDigestinstances passed to it generally won't be.- Since:
- 1.22.0
- See Also:
- Git Internals – Git Objects, SWHID Specification
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classGitIdentifiers.FileModeThe type of a Git tree entry, which maps to a Unix file-mode string.static classGitIdentifiers.TreeIdBuilderBuilds a Git tree identifier for a virtual directory structure, such as the contents of an archive.
-
Method Summary
All Methods Static Methods Concrete Methods Modifier and Type Method Description static byte[]blobId(java.security.MessageDigest messageDigest, byte[] data)Reads through a byte array and returns a generalized Git blob identifier.static byte[]blobId(java.security.MessageDigest messageDigest, long dataSize, java.io.InputStream data)Reads through a stream of known size and returns a generalized Git blob identifier, without buffering.static byte[]blobId(java.security.MessageDigest messageDigest, java.nio.file.Path data)Reads through a file and returns a generalized Git blob identifier.static byte[]treeId(java.security.MessageDigest messageDigest, java.nio.file.Path data)Reads through a directory and returns a generalized Git tree identifier.static GitIdentifiers.TreeIdBuildertreeIdBuilder(java.security.MessageDigest messageDigest)Returns a newGitIdentifiers.TreeIdBuilderfor constructing a generalized Git tree identifier from a virtual directory structure, such as the contents of an archive.
-
-
-
Method Detail
-
blobId
public static byte[] blobId(java.security.MessageDigest messageDigest, byte[] data)
Reads through a byte array and returns a generalized Git blob identifier.The identifier is computed in the way described by the SWHID contents identifier, but it can use any hash algorithm.
When the hash algorithm is SHA-1, the identifier is identical to Git blob identifier and SWHID contents identifier.
- Parameters:
messageDigest- The MessageDigest to use (for example SHA-1).data- Data to digest.- Returns:
- A generalized Git blob identifier.
-
blobId
public static byte[] blobId(java.security.MessageDigest messageDigest, long dataSize, java.io.InputStream data) throws java.io.IOException
Reads through a stream of known size and returns a generalized Git blob identifier, without buffering.When the size of the content is known in advance, this overload streams
datadirectly through the digest without buffering the full content in memory.When the hash algorithm is SHA-1, the identifier is identical to Git blob identifier and SWHID contents identifier.
- Parameters:
messageDigest- The MessageDigest to use (for example SHA-1).dataSize- The exact number of bytes indata.data- Stream to digest.- Returns:
- A generalized Git blob identifier.
- Throws:
java.io.IOException- On error reading the stream.
-
blobId
public static byte[] blobId(java.security.MessageDigest messageDigest, java.nio.file.Path data) throws java.io.IOException
Reads through a file and returns a generalized Git blob identifier.The identifier is computed in the way described by the SWHID contents identifier, but it can use any hash algorithm.
When the hash algorithm is SHA-1, the identifier is identical to Git blob identifier and SWHID contents identifier.
- Parameters:
messageDigest- The MessageDigest to use (for example SHA-1).data- Path to the file to digest.- Returns:
- A generalized Git blob identifier.
- Throws:
java.io.IOException- On error accessing the file.
-
treeId
public static byte[] treeId(java.security.MessageDigest messageDigest, java.nio.file.Path data) throws java.io.IOException
Reads through a directory and returns a generalized Git tree identifier.The identifier is computed in the way described by the SWHID directory identifier, but it can use any hash algorithm.
When the hash algorithm is SHA-1, the identifier is identical to Git tree identifier and SWHID directory identifier.
- Parameters:
messageDigest- The MessageDigest to use (for example SHA-1).data- Path to the directory to digest.- Returns:
- A generalized Git tree identifier.
- Throws:
java.io.IOException- On error accessing the directory or its contents.
-
treeIdBuilder
public static GitIdentifiers.TreeIdBuilder treeIdBuilder(java.security.MessageDigest messageDigest)
Returns a newGitIdentifiers.TreeIdBuilderfor constructing a generalized Git tree identifier from a virtual directory structure, such as the contents of an archive.The identifier is computed in the way described by the SWHID directory identifier, but it can use any hash algorithm.
When the hash algorithm is SHA-1, the identifier is identical to Git tree identifier and SWHID directory identifier.
- Parameters:
messageDigest- The MessageDigest to use (for example SHA-1).- Returns:
- A new
GitIdentifiers.TreeIdBuilder.
-
-