From 0eed4b0d2121a206d4eba81aa4a1888125acbe3e Mon Sep 17 00:00:00 2001 From: Thunderblade73 <85900443+Thunderblade73@users.noreply.github.com> Date: Thu, 25 Apr 2024 11:53:59 +0200 Subject: Backend: Queue drain Functions (#1182) Co-authored-by: hannibal2 <24389977+hannibal00212@users.noreply.github.com> --- .../at/hannibal2/skyhanni/utils/CollectionUtils.kt | 32 ++++++++++++++++------ 1 file changed, 23 insertions(+), 9 deletions(-) (limited to 'src/main') diff --git a/src/main/java/at/hannibal2/skyhanni/utils/CollectionUtils.kt b/src/main/java/at/hannibal2/skyhanni/utils/CollectionUtils.kt index 3082112ce..d33729ae3 100644 --- a/src/main/java/at/hannibal2/skyhanni/utils/CollectionUtils.kt +++ b/src/main/java/at/hannibal2/skyhanni/utils/CollectionUtils.kt @@ -4,14 +4,35 @@ import at.hannibal2.skyhanni.utils.NEUItems.getItemStack import at.hannibal2.skyhanni.utils.renderables.Renderable import net.minecraft.item.ItemStack import java.util.Collections +import java.util.Queue import java.util.WeakHashMap -import java.util.concurrent.ConcurrentLinkedQueue object CollectionUtils { - fun ConcurrentLinkedQueue.drainTo(list: MutableCollection) { + inline fun , reified E> T.drainForEach(action: (E) -> Unit): T { + while (true) + action(this.poll() ?: break) + return this + } + + inline fun , reified E> T.drain(amount: Int): T { + for (i in 1..amount) + this.poll() ?: break + return this + } + + inline fun > + Queue.drainTo(list: L, action: (E) -> K): L { + while (true) + list.add(action(this.poll() ?: break)) + return list + } + + inline fun > + Queue.drainTo(list: L): L { while (true) list.add(this.poll() ?: break) + return list } // Let garbage collector handle the removal of entries in this list @@ -143,13 +164,6 @@ object CollectionUtils { return toList().sorted().reversed().toMap() } - inline fun ConcurrentLinkedQueue.drainForEach(action: (T) -> Unit) { - while (true) { - val value = this.poll() ?: break - action(value) - } - } - fun Sequence.takeWhileInclusive(predicate: (T) -> Boolean) = sequence { with(iterator()) { while (hasNext()) { -- cgit