diff options
author | Matthias Sohn <matthias.sohn@sap.com> | 2023-09-20 09:59:30 +0200 |
---|---|---|
committer | Matthias Sohn <matthias.sohn@sap.com> | 2023-09-25 16:15:34 +0200 |
commit | d0b9ab1c4af838225be36fd22479b88c184d10ca (patch) | |
tree | a017fb6c4b128e8d064b325c71826d34a92c049a | |
parent | ba2f9affc677d39e2276a2758bfabff61927ba02 (diff) | |
download | jgit-d0b9ab1c4af838225be36fd22479b88c184d10ca.tar.gz jgit-d0b9ab1c4af838225be36fd22479b88c184d10ca.zip |
[errorprone] Directly implement functional interface
instead of saving it in a lambda. Prefer to implement the functional
interface method directly and use a method reference instead.
See https://errorprone.info/bugpattern/UnnecessaryLambda
Change-Id: I7f7ebd27cd6354545c157960718d9845882e1732
-rw-r--r-- | org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/PackWriter.java | 60 |
1 files changed, 31 insertions, 29 deletions
diff --git a/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/PackWriter.java b/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/PackWriter.java index dcd360dbb3..fe3ab8b599 100644 --- a/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/PackWriter.java +++ b/org.eclipse.jgit/src/org/eclipse/jgit/internal/storage/pack/PackWriter.java @@ -146,44 +146,46 @@ public class PackWriter implements AutoCloseable { private static final Map<WeakReference<PackWriter>, Boolean> instances = new ConcurrentHashMap<>(); - private static final Iterable<PackWriter> instancesIterable = () -> new Iterator<>() { + private static Iterator<PackWriter> instancesIterable() { + return new Iterator<>() { - private final Iterator<WeakReference<PackWriter>> it = instances - .keySet().iterator(); + private final Iterator<WeakReference<PackWriter>> it = instances + .keySet().iterator(); - private PackWriter next; + private PackWriter next; - @Override - public boolean hasNext() { - if (next != null) { - return true; - } - while (it.hasNext()) { - WeakReference<PackWriter> ref = it.next(); - next = ref.get(); + @Override + public boolean hasNext() { if (next != null) { return true; } - it.remove(); + while (it.hasNext()) { + WeakReference<PackWriter> ref = it.next(); + next = ref.get(); + if (next != null) { + return true; + } + it.remove(); + } + return false; } - return false; - } - @Override - public PackWriter next() { - if (hasNext()) { - PackWriter result = next; - next = null; - return result; + @Override + public PackWriter next() { + if (hasNext()) { + PackWriter result = next; + next = null; + return result; + } + throw new NoSuchElementException(); } - throw new NoSuchElementException(); - } - @Override - public void remove() { - throw new UnsupportedOperationException(); - } - }; + @Override + public void remove() { + throw new UnsupportedOperationException(); + } + }; + } /** * Get all allocated, non-released PackWriters instances. @@ -191,7 +193,7 @@ public class PackWriter implements AutoCloseable { * @return all allocated, non-released PackWriters instances. */ public static Iterable<PackWriter> getInstances() { - return instancesIterable; + return PackWriter::instancesIterable; } @SuppressWarnings("unchecked") |