Class SupplyingBarrierStep<S,E>
- java.lang.Object
-
- org.apache.tinkerpop.gremlin.process.traversal.step.util.AbstractStep<S,E>
-
- org.apache.tinkerpop.gremlin.process.traversal.step.util.SupplyingBarrierStep<S,E>
-
- All Implemented Interfaces:
Serializable,Cloneable,Iterator<Traverser.Admin<E>>,Step<S,E>,Barrier<Boolean>,MemoryComputing<Boolean>
- Direct Known Subclasses:
SideEffectCapStep
public abstract class SupplyingBarrierStep<S,E> extends AbstractStep<S,E> implements Barrier<Boolean>
- Author:
- Marko A. Rodriguez (http://markorodriguez.com)
- See Also:
- Serialized Form
-
-
Field Summary
-
Fields inherited from class org.apache.tinkerpop.gremlin.process.traversal.step.util.AbstractStep
id, labels, nextEnd, nextStep, previousStep, starts, traversal, traverserStepIdAndLabelsSetByChild
-
-
Constructor Summary
Constructors Constructor Description SupplyingBarrierStep(Traversal.Admin traversal)
-
Method Summary
All Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description voidaddBarrier(Boolean barrier)Add a barrier to the step.voidaddStart(Traverser.Admin<S> start)Add a singleTraverser.Adminto the step.voidaddStarts(Iterator<Traverser.Admin<S>> starts)Add an iterator ofTraverser.Adminobjects of type S to the step.SupplyingBarrierStep<S,E>clone()Cloning is used to duplicate steps for the purpose of traversal optimization and OLTP replication.voiddone()A way to hard set that the barrier is complete.MemoryComputeKey<Boolean>getMemoryComputeKey()TheMemoryComputeKeythat will be used by this step.booleanhasNextBarrier()Whether or not the step has an accessible barrier.BooleannextBarrier()Get the next barrier within this step.voidprocessAllStarts()Process all left traversers by do not yield the resultant output.Traverser.Admin<E>processNextStart()voidreset()Reset the state of the step such that it has no incoming starts.protected abstract Esupply()-
Methods inherited from class org.apache.tinkerpop.gremlin.process.traversal.step.util.AbstractStep
addLabel, clearLabels, equals, getId, getLabels, getNextStep, getPreviousStep, getStarts, getTraversal, hashCode, hasNext, hasStarts, isTraverserStepIdAndLabelsSetByChild, next, prepareTraversalForNextStep, removeLabel, setId, setNextStep, setPreviousStep, setTraversal, toString
-
Methods inherited from class java.lang.Object
finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface java.util.Iterator
forEachRemaining, remove
-
Methods inherited from interface org.apache.tinkerpop.gremlin.process.traversal.Step
equals, getRequirements
-
-
-
-
Constructor Detail
-
SupplyingBarrierStep
public SupplyingBarrierStep(Traversal.Admin traversal)
-
-
Method Detail
-
supply
protected abstract E supply()
-
addStarts
public void addStarts(Iterator<Traverser.Admin<S>> starts)
Description copied from interface:StepAdd an iterator ofTraverser.Adminobjects of type S to the step.
-
addStart
public void addStart(Traverser.Admin<S> start)
Description copied from interface:StepAdd a singleTraverser.Adminto the step.
-
reset
public void reset()
Description copied from interface:StepReset the state of the step such that it has no incoming starts. Internal states are to be reset, but any sideEffect data structures are not to be recreated.
-
processNextStart
public Traverser.Admin<E> processNextStart()
- Specified by:
processNextStartin classAbstractStep<S,E>
-
clone
public SupplyingBarrierStep<S,E> clone()
Description copied from interface:StepCloning is used to duplicate steps for the purpose of traversal optimization and OLTP replication. When cloning a step, it is important that the steps, the cloned step is equivalent to the state of the step whenStep.reset()is called. Moreover, the previous and next steps should be set toEmptyStep.
-
processAllStarts
public void processAllStarts()
Description copied from interface:BarrierProcess all left traversers by do not yield the resultant output. This method is useful for steps likeReducingBarrierStep, where traversers can be processed "on the fly" and thus, reduce memory consumption.- Specified by:
processAllStartsin interfaceBarrier<S>
-
hasNextBarrier
public boolean hasNextBarrier()
Description copied from interface:BarrierWhether or not the step has an accessible barrier.- Specified by:
hasNextBarrierin interfaceBarrier<S>- Returns:
- whether a barrier exists or not
-
nextBarrier
public Boolean nextBarrier() throws NoSuchElementException
Description copied from interface:BarrierGet the next barrier within this step. Barriers from parallel steps can be the be merged to create a single step with merge barriers.- Specified by:
nextBarrierin interfaceBarrier<S>- Returns:
- the next barrier of the step
- Throws:
NoSuchElementException
-
addBarrier
public void addBarrier(Boolean barrier)
Description copied from interface:BarrierAdd a barrier to the step. This typically happens when multiple parallel barriers need to become one barrier at a single step.- Specified by:
addBarrierin interfaceBarrier<S>- Parameters:
barrier- the barrier to merge in
-
done
public void done()
Description copied from interface:BarrierA way to hard set that the barrier is complete. This is necessary when parallel barriers don't all have barriers and need hard resetting. The default implementation does nothing.
-
getMemoryComputeKey
public MemoryComputeKey<Boolean> getMemoryComputeKey()
Description copied from interface:MemoryComputingTheMemoryComputeKeythat will be used by this step.- Specified by:
getMemoryComputeKeyin interfaceMemoryComputing<S>- Returns:
- the MemoryComputeKey to use
-
-