Files
runelite/runescape-client/src/main/java/IterableDualNodeQueueIterator.java
2021-11-03 22:50:34 +11:00

65 lines
1.4 KiB
Java

import java.util.Iterator;
import net.runelite.mapping.Export;
import net.runelite.mapping.Implements;
import net.runelite.mapping.ObfuscatedName;
import net.runelite.mapping.ObfuscatedSignature;
@ObfuscatedName("ld")
@Implements("IterableDualNodeQueueIterator")
public class IterableDualNodeQueueIterator implements Iterator {
@ObfuscatedName("i")
@ObfuscatedSignature(
descriptor = "Llm;"
)
@Export("queue")
IterableDualNodeQueue queue;
@ObfuscatedName("w")
@ObfuscatedSignature(
descriptor = "Lnt;"
)
@Export("head")
DualNode head;
@ObfuscatedName("s")
@ObfuscatedSignature(
descriptor = "Lnt;"
)
@Export("last")
DualNode last;
@ObfuscatedSignature(
descriptor = "(Llm;)V"
)
IterableDualNodeQueueIterator(IterableDualNodeQueue var1) {
this.last = null; // L: 9
this.queue = var1; // L: 12
this.head = this.queue.sentinel.previousDual; // L: 13
this.last = null; // L: 14
} // L: 15
public boolean hasNext() {
return this.queue.sentinel != this.head; // L: 29
}
public Object next() {
DualNode var1 = this.head; // L: 18
if (var1 == this.queue.sentinel) { // L: 19
var1 = null; // L: 20
this.head = null; // L: 21
} else {
this.head = var1.previousDual; // L: 23
}
this.last = var1; // L: 24
return var1; // L: 25
}
public void remove() {
if (this.last == null) { // L: 33
throw new IllegalStateException();
} else {
this.last.removeDual(); // L: 34
this.last = null; // L: 35
}
} // L: 36
}