io.shiftleft.overflowdb.DummyEdgeIterator Maven / Gradle / Ivy
package io.shiftleft.overflowdb;
import org.apache.tinkerpop.gremlin.structure.Direction;
import org.apache.tinkerpop.gremlin.structure.Edge;
import java.util.Iterator;
import java.util.NoSuchElementException;
public class DummyEdgeIterator implements Iterator {
private final Object[] array;
private int current;
private final int begin;
private final int exclusiveEnd;
private final int strideSize;
private final Direction direction;
private final String label;
private final NodeRef thisRef;
public DummyEdgeIterator(Object[] array, int begin, int exclusiveEnd, int strideSize,
Direction direction, String label, NodeRef thisRef) {
this.array = array;
this.begin = begin;
this.current = begin;
this.exclusiveEnd = exclusiveEnd;
this.strideSize = strideSize;
this.direction = direction;
this.label = label;
this.thisRef = thisRef;
}
@Override
public boolean hasNext() {
/* there may be holes, e.g. if an edge was removed */
while (current < exclusiveEnd && array[current] == null) {
current += strideSize;
}
return current < exclusiveEnd;
}
@Override
public Edge next() {
if (!hasNext()) throw new NoSuchElementException();
NodeRef otherRef = (NodeRef) array[current];
OdbEdge dummyEdge;
if (direction == Direction.OUT) {
dummyEdge = thisRef.get().instantiateDummyEdge(label, thisRef, otherRef);
dummyEdge.setOutBlockOffset(current - begin);
} else {
dummyEdge = thisRef.get().instantiateDummyEdge(label, otherRef, thisRef);
dummyEdge.setInBlockOffset(current - begin);
}
current += strideSize;
return dummyEdge;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy