diff options
author | Hugo Arès <hugo.ares@ericsson.com> | 2014-06-05 15:16:26 -0400 |
---|---|---|
committer | Hugo Arès <hugo.ares@ericsson.com> | 2014-06-05 15:20:04 -0400 |
commit | d439c8dfe5ec521fc0f66cf956d9a5c7e63cadd3 (patch) | |
tree | 970c510af81acce1d7e30dd011f8546947791d32 | |
parent | 64b0531c35674df21ed02ab96d5f5bc6f5af7052 (diff) | |
download | jgit-d439c8dfe5ec521fc0f66cf956d9a5c7e63cadd3.tar.gz jgit-d439c8dfe5ec521fc0f66cf956d9a5c7e63cadd3.zip |
Fix DeltaTask infinite loop
DeltaTask$Block.partitionTask was doing an infinite loop if number of
threads was greater than the totalWeight. The weightPerThread was 0
which was causing the infinite loop. Set the weightPerThread to a
minimal value of one.
Bug: 420915
Change-Id: Ia8e3ad956d53d8193937b7fa1bc19aafde9767ff
Signed-off-by: Hugo Arès <hugo.ares@ericsson.com>
-rw-r--r-- | org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/DeltaTask.java | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/DeltaTask.java b/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/DeltaTask.java index c4b01949d1..9534053bfe 100644 --- a/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/DeltaTask.java +++ b/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/DeltaTask.java @@ -121,7 +121,7 @@ final class DeltaTask implements Callable<Object> { ArrayList<WeightedPath> topPaths = computeTopPaths(); Iterator<WeightedPath> topPathItr = topPaths.iterator(); int nextTop = 0; - long weightPerThread = totalWeight / threads; + long weightPerThread = Math.max(totalWeight / threads, 1); for (int i = beginIndex; i < endIndex;) { DeltaTask task = new DeltaTask(this); long w = 0; |