diff options
author | Simon Brandhof <simon.brandhof@gmail.com> | 2013-02-08 10:36:07 +0100 |
---|---|---|
committer | Simon Brandhof <simon.brandhof@gmail.com> | 2013-02-08 10:36:21 +0100 |
commit | be08b3ca873dce25a7a05b78eb781aee7d344c70 (patch) | |
tree | 52be982f7e1ce4ec8d4fef53ddb4bc62e794bba7 /sonar-home/src/main/java/org/sonar/home/cache | |
parent | 7ce02467a0b3a5270327783a22b163a3210992fd (diff) | |
download | sonarqube-be08b3ca873dce25a7a05b78eb781aee7d344c70.tar.gz sonarqube-be08b3ca873dce25a7a05b78eb781aee7d344c70.zip |
SONAR-2291 fix performance issue when computing file hashes
Diffstat (limited to 'sonar-home/src/main/java/org/sonar/home/cache')
-rw-r--r-- | sonar-home/src/main/java/org/sonar/home/cache/FileHashes.java | 17 |
1 files changed, 13 insertions, 4 deletions
diff --git a/sonar-home/src/main/java/org/sonar/home/cache/FileHashes.java b/sonar-home/src/main/java/org/sonar/home/cache/FileHashes.java index 89a973fd2f4..28066cf5b94 100644 --- a/sonar-home/src/main/java/org/sonar/home/cache/FileHashes.java +++ b/sonar-home/src/main/java/org/sonar/home/cache/FileHashes.java @@ -36,6 +36,8 @@ import java.security.MessageDigest; */ public class FileHashes { + private static final int STREAM_BUFFER_LENGTH = 1024; + public String of(File file) { try { return of(new FileInputStream(file)); @@ -51,10 +53,7 @@ public class FileHashes { DigestInputStream digestInputStream = null; try { MessageDigest digest = MessageDigest.getInstance("MD5"); - digestInputStream = new DigestInputStream(input, digest); - while (digestInputStream.read() != -1) { - } - byte[] hash = digest.digest(); + byte[] hash = digest(input, digest); return toHex(hash); } catch (Exception e) { @@ -66,6 +65,16 @@ public class FileHashes { } } + private byte[] digest(InputStream input, MessageDigest digest) throws IOException { + final byte[] buffer = new byte[STREAM_BUFFER_LENGTH]; + int read = input.read(buffer, 0, STREAM_BUFFER_LENGTH); + while (read > -1) { + digest.update(buffer, 0, read); + read = input.read(buffer, 0, STREAM_BUFFER_LENGTH); + } + return digest.digest(); + } + static String toHex(byte[] bytes) { BigInteger bi = new BigInteger(1, bytes); return String.format("%0" + (bytes.length << 1) + "X", bi); |