Class CollectingBarrierStep<S>
- java.lang.Object
- 
- org.apache.tinkerpop.gremlin.process.traversal.step.util.AbstractStep<S,S>
- 
- org.apache.tinkerpop.gremlin.process.traversal.step.util.CollectingBarrierStep<S>
 
 
- 
- All Implemented Interfaces:
- Serializable,- Cloneable,- Iterator<Traverser.Admin<S>>,- Step<S,S>,- Barrier<TraverserSet<S>>,- FilteringBarrier<TraverserSet<S>>,- MemoryComputing<TraverserSet<S>>
 - Direct Known Subclasses:
- LambdaCollectingBarrierStep,- OrderGlobalStep,- SampleGlobalStep
 
 public abstract class CollectingBarrierStep<S> extends AbstractStep<S,S> implements FilteringBarrier<TraverserSet<S>> - Author:
- Marko A. Rodriguez (http://markorodriguez.com)
- See Also:
- Serialized Form
 
- 
- 
Field SummaryFields Modifier and Type Field Description protected TraverserSet<S>traverserSet- 
Fields inherited from class org.apache.tinkerpop.gremlin.process.traversal.step.util.AbstractStepid, labels, nextEnd, nextStep, previousStep, starts, traversal, traverserStepIdAndLabelsSetByChild
 
- 
 - 
Constructor SummaryConstructors Constructor Description CollectingBarrierStep(Traversal.Admin traversal)CollectingBarrierStep(Traversal.Admin traversal, int maxBarrierSize)
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description voidaddBarrier(TraverserSet<S> barrier)Add a barrier to the step.abstract voidbarrierConsumer(TraverserSet<S> traverserSet)CollectingBarrierStep<S>clone()Cloning is used to duplicate steps for the purpose of traversal optimization and OLTP replication.TraverserSet<S>getEmptyBarrier()If a barrier is unproductive then provide an empty object suitable to the implementation which can be used to represent that state.MemoryComputeKey<TraverserSet<S>>getMemoryComputeKey()TheMemoryComputeKeythat will be used by this step.Set<TraverserRequirement>getRequirements()Provide the necessaryTraverserRequirementthat must be met by the traverser in order for the step to function properly.inthashCode()booleanhasNextBarrier()Whether or not the step has an accessible barrier.TraverserSet<S>nextBarrier()Get the next barrier within this step.voidprocessAllStarts()Process all left traversers by do not yield the resultant output.Traverser.Admin<S>processNextStart()voidreset()Reset the state of the step such that it has no incoming starts.StringtoString()- 
Methods inherited from class org.apache.tinkerpop.gremlin.process.traversal.step.util.AbstractStepaddLabel, addStart, addStarts, clearLabels, equals, getId, getLabels, getNextStep, getPreviousStep, getStarts, getTraversal, hasNext, hasStarts, isTraverserStepIdAndLabelsSetByChild, next, prepareTraversalForNextStep, removeLabel, setId, setNextStep, setPreviousStep, setTraversal
 - 
Methods inherited from class java.lang.Objectfinalize, getClass, notify, notifyAll, wait, wait, wait
 - 
Methods inherited from interface java.util.IteratorforEachRemaining, remove
 
- 
 
- 
- 
- 
Field Detail- 
traverserSetprotected TraverserSet<S> traverserSet 
 
- 
 - 
Constructor Detail- 
CollectingBarrierSteppublic CollectingBarrierStep(Traversal.Admin traversal) 
 - 
CollectingBarrierSteppublic CollectingBarrierStep(Traversal.Admin traversal, int maxBarrierSize) 
 
- 
 - 
Method Detail- 
barrierConsumerpublic abstract void barrierConsumer(TraverserSet<S> traverserSet) 
 - 
getRequirementspublic Set<TraverserRequirement> getRequirements() Description copied from interface:StepProvide the necessaryTraverserRequirementthat must be met by the traverser in order for the step to function properly. The provided default implements returns an empty set.- Specified by:
- getRequirementsin interface- Step<S,S>
- Returns:
- the set of requirements
 
 - 
processAllStartspublic 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 interface- Barrier<S>
 
 - 
hasNextBarrierpublic boolean hasNextBarrier() Description copied from interface:BarrierWhether or not the step has an accessible barrier.- Specified by:
- hasNextBarrierin interface- Barrier<S>
- Returns:
- whether a barrier exists or not
 
 - 
nextBarrierpublic TraverserSet<S> 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 interface- Barrier<S>
- Returns:
- the next barrier of the step
- Throws:
- NoSuchElementException
 
 - 
getEmptyBarrierpublic TraverserSet<S> getEmptyBarrier() Description copied from interface:BarrierIf a barrier is unproductive then provide an empty object suitable to the implementation which can be used to represent that state. This is important for cases likeby(out().order().fold())where theorder()might filter but thefold()means the traversal is productive.- Specified by:
- getEmptyBarrierin interface- Barrier<S>
 
 - 
addBarrierpublic void addBarrier(TraverserSet<S> 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 interface- Barrier<S>
- Parameters:
- barrier- the barrier to merge in
 
 - 
processNextStartpublic Traverser.Admin<S> processNextStart() - Specified by:
- processNextStartin class- AbstractStep<S,S>
 
 - 
clonepublic CollectingBarrierStep<S> 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.
 - 
toStringpublic String toString() - Overrides:
- toStringin class- AbstractStep<S,S>
 
 - 
hashCodepublic int hashCode() - Overrides:
- hashCodein class- AbstractStep<S,S>
 
 - 
resetpublic 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.
 - 
getMemoryComputeKeypublic MemoryComputeKey<TraverserSet<S>> getMemoryComputeKey() Description copied from interface:MemoryComputingTheMemoryComputeKeythat will be used by this step.- Specified by:
- getMemoryComputeKeyin interface- MemoryComputing<S>
- Returns:
- the MemoryComputeKey to use
 
 
- 
 
-