aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/gregtech/api/objects
diff options
context:
space:
mode:
authorTimeConqueror <timeconqueror999@gmail.com>2021-08-03 22:34:50 +0300
committerTimeConqueror <timeconqueror999@gmail.com>2021-08-03 22:34:50 +0300
commitb9468785aa264ba0c1fcf295bb15260bb47c90c0 (patch)
tree7f16876d9bce26bbf0b1857cfd79155cd9f3f15d /src/main/java/gregtech/api/objects
parent40dbbe312ddb16ac84024e3bed8dbae1a2c6c124 (diff)
downloadGT5-Unofficial-b9468785aa264ba0c1fcf295bb15260bb47c90c0.tar.gz
GT5-Unofficial-b9468785aa264ba0c1fcf295bb15260bb47c90c0.tar.bz2
GT5-Unofficial-b9468785aa264ba0c1fcf295bb15260bb47c90c0.zip
GT_Recipe: speedup
Diffstat (limited to 'src/main/java/gregtech/api/objects')
-rw-r--r--src/main/java/gregtech/api/objects/iterators/ArrayIterator.java24
-rw-r--r--src/main/java/gregtech/api/objects/iterators/MergedIterator.java30
-rw-r--r--src/main/java/gregtech/api/objects/iterators/NonNullIterator.java36
3 files changed, 90 insertions, 0 deletions
diff --git a/src/main/java/gregtech/api/objects/iterators/ArrayIterator.java b/src/main/java/gregtech/api/objects/iterators/ArrayIterator.java
new file mode 100644
index 0000000000..267a132ad5
--- /dev/null
+++ b/src/main/java/gregtech/api/objects/iterators/ArrayIterator.java
@@ -0,0 +1,24 @@
+package gregtech.api.objects.iterators;
+
+import java.util.Iterator;
+
+public class ArrayIterator<T> implements Iterator<T> {
+ private final T[] arr;
+ private int offset;
+
+ public ArrayIterator(T[] arr) {
+ this.arr = arr;
+ }
+
+ @Override
+ public boolean hasNext() {
+ return offset != arr.length;
+ }
+
+ @Override
+ public T next() {
+ T out = arr[offset];
+ offset++;
+ return out;
+ }
+}
diff --git a/src/main/java/gregtech/api/objects/iterators/MergedIterator.java b/src/main/java/gregtech/api/objects/iterators/MergedIterator.java
new file mode 100644
index 0000000000..77fac8d22f
--- /dev/null
+++ b/src/main/java/gregtech/api/objects/iterators/MergedIterator.java
@@ -0,0 +1,30 @@
+package gregtech.api.objects.iterators;
+
+import java.util.Iterator;
+
+public class MergedIterator<T> implements Iterator<T> {
+ private final Iterator<T>[] inners;
+ private int current;
+
+ @SafeVarargs
+ public MergedIterator(Iterator<T>... iterators) {
+ inners = iterators;
+ current = 0;
+ }
+
+ public boolean hasNext() {
+ while (current < inners.length && !inners[current].hasNext()) {
+ current++;
+ }
+
+ return current < inners.length;
+ }
+
+ public T next() {
+ while (current < inners.length && !inners[current].hasNext()) {
+ current++;
+ }
+
+ return inners[current].next();
+ }
+}
diff --git a/src/main/java/gregtech/api/objects/iterators/NonNullIterator.java b/src/main/java/gregtech/api/objects/iterators/NonNullIterator.java
new file mode 100644
index 0000000000..22dd33ba2b
--- /dev/null
+++ b/src/main/java/gregtech/api/objects/iterators/NonNullIterator.java
@@ -0,0 +1,36 @@
+package gregtech.api.objects.iterators;
+
+import java.util.Iterator;
+
+public class NonNullIterator<T> implements Iterator<T> {
+ private final Iterator<T> internal;
+ private T last = null;
+
+ public NonNullIterator(Iterator<T> in) {
+ this.internal = in;
+ }
+
+ @Override
+ public boolean hasNext() {
+ while (last == null) {
+ if (internal.hasNext()) {
+ last = internal.next();
+ } else {
+ return false;
+ }
+ }
+
+ return true;
+ }
+
+ @Override
+ public T next() {
+ while (last == null) {
+ last = internal.next();
+ }
+
+ T temp = last;
+ last = null;
+ return temp;
+ }
+}