minecraft-src/net/minecraft/client/searchtree/MergingUniqueIterator.java
2025-07-04 01:41:11 +03:00

42 lines
1.3 KiB
Java

package net.minecraft.client.searchtree;
import com.google.common.collect.AbstractIterator;
import com.google.common.collect.Iterators;
import com.google.common.collect.PeekingIterator;
import java.util.Comparator;
import java.util.Iterator;
import net.fabricmc.api.EnvType;
import net.fabricmc.api.Environment;
@Environment(EnvType.CLIENT)
public class MergingUniqueIterator<T> extends AbstractIterator<T> {
private final PeekingIterator<T> firstIterator;
private final PeekingIterator<T> secondIterator;
private final Comparator<T> comparator;
public MergingUniqueIterator(Iterator<T> firstIterator, Iterator<T> secondIterator, Comparator<T> comparator) {
this.firstIterator = Iterators.peekingIterator(firstIterator);
this.secondIterator = Iterators.peekingIterator(secondIterator);
this.comparator = comparator;
}
@Override
protected T computeNext() {
boolean bl = !this.firstIterator.hasNext();
boolean bl2 = !this.secondIterator.hasNext();
if (bl && bl2) {
return this.endOfData();
} else if (bl) {
return this.secondIterator.next();
} else if (bl2) {
return this.firstIterator.next();
} else {
int i = this.comparator.compare(this.firstIterator.peek(), this.secondIterator.peek());
if (i == 0) {
this.secondIterator.next();
}
return i <= 0 ? this.firstIterator.next() : this.secondIterator.next();
}
}
}