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 extends AbstractIterator { private final PeekingIterator firstIterator; private final PeekingIterator secondIterator; private final Comparator comparator; public MergingUniqueIterator(Iterator firstIterator, Iterator secondIterator, Comparator 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(); } } }