Class AggregateGlobalStep<S>
- java.lang.Object
-
- org.apache.tinkerpop.gremlin.process.traversal.step.util.AbstractStep<S,S>
-
- org.apache.tinkerpop.gremlin.process.traversal.step.sideEffect.AggregateGlobalStep<S>
-
- All Implemented Interfaces:
Serializable,AutoCloseable,Cloneable,Iterator<Traverser.Admin<S>>,Step<S,S>,Barrier<TraverserSet<S>>,ByModulating,Generating<Collection,Collection>,LocalBarrier<S>,MemoryComputing<TraverserSet<S>>,SideEffectCapable<Collection,Collection>,TraversalParent
public final class AggregateGlobalStep<S> extends AbstractStep<S,S> implements SideEffectCapable<Collection,Collection>, TraversalParent, ByModulating, LocalBarrier<S>
- 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 AggregateGlobalStep(Traversal.Admin traversal, String sideEffectKey)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddBarrier(TraverserSet<S> barrier)Add a barrier to the step.AggregateGlobalStep<S>clone()Cloning is used to duplicate steps for the purpose of traversal optimization and OLTP replication.List<Traversal.Admin<S,Object>>getLocalChildren()Set<TraverserRequirement>getRequirements()Provide the necessaryTraverserRequirementthat must be met by the traverser in order for the step to function properly.StringgetSideEffectKey()The side-effect key of the step.inthashCode()booleanhasNextBarrier()Whether or not the step has an accessible barrier.voidmodulateBy(Traversal.Admin<?,?> aggregateTraversal)TraverserSet<S>nextBarrier()Get the next barrier within this step.voidprocessAllStarts()Process all left traversers by do not yield the resultant output.protected Traverser.Admin<S>processNextStart()voidreplaceLocalChild(Traversal.Admin<?,?> oldTraversal, Traversal.Admin<?,?> newTraversal)voidreset()Reset the state of the step such that it has no incoming starts.voidsetTraversal(Traversal.Admin<?,?> parentTraversal)Set theTraversalthat this step is contained within.StringtoString()-
Methods inherited from class org.apache.tinkerpop.gremlin.process.traversal.step.util.AbstractStep
addLabel, addStart, addStarts, clearLabels, equals, getId, getLabels, getNextStep, getPreviousStep, getStarts, getTraversal, hasNext, hasStarts, isTraverserStepIdAndLabelsSetByChild, next, prepareTraversalForNextStep, removeLabel, setId, setNextStep, setPreviousStep
-
Methods inherited from class java.lang.Object
finalize, getClass, notify, notifyAll, wait, wait, wait
-
Methods inherited from interface org.apache.tinkerpop.gremlin.process.traversal.step.ByModulating
modulateBy, modulateBy, modulateBy, modulateBy, modulateBy, modulateBy, modulateBy, modulateBy, modulateBy, modulateBy, modulateBy
-
Methods inherited from interface org.apache.tinkerpop.gremlin.process.traversal.step.Generating
generateFinalResult
-
Methods inherited from interface java.util.Iterator
forEachRemaining, remove
-
Methods inherited from interface org.apache.tinkerpop.gremlin.process.traversal.step.LocalBarrier
getMemoryComputeKey
-
Methods inherited from interface org.apache.tinkerpop.gremlin.process.traversal.step.TraversalParent
addGlobalChild, addLocalChild, asStep, close, getGlobalChildren, getSelfAndChildRequirements, integrateChild, removeGlobalChild, removeLocalChild
-
-
-
-
Constructor Detail
-
AggregateGlobalStep
public AggregateGlobalStep(Traversal.Admin traversal, String sideEffectKey)
-
-
Method Detail
-
getSideEffectKey
public String getSideEffectKey()
Description copied from interface:SideEffectCapableThe side-effect key of the step.- Specified by:
getSideEffectKeyin interfaceSideEffectCapable<Collection,Collection>- Returns:
- the side-effect key
-
toString
public String toString()
- Overrides:
toStringin classAbstractStep<S,S>
-
modulateBy
public void modulateBy(Traversal.Admin<?,?> aggregateTraversal)
- Specified by:
modulateByin interfaceByModulating
-
replaceLocalChild
public void replaceLocalChild(Traversal.Admin<?,?> oldTraversal, Traversal.Admin<?,?> newTraversal)
- Specified by:
replaceLocalChildin interfaceTraversalParent
-
getLocalChildren
public List<Traversal.Admin<S,Object>> getLocalChildren()
- Specified by:
getLocalChildrenin interfaceTraversalParent
-
getRequirements
public 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 interfaceStep<S,S>- Returns:
- the set of requirements
-
clone
public AggregateGlobalStep<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.
-
setTraversal
public void setTraversal(Traversal.Admin<?,?> parentTraversal)
Description copied from interface:StepSet theTraversalthat this step is contained within.- Specified by:
setTraversalin interfaceStep<S,S>- Overrides:
setTraversalin classAbstractStep<S,S>- Parameters:
parentTraversal- the new traversal for this step
-
hashCode
public int hashCode()
- Overrides:
hashCodein classAbstractStep<S,S>
-
processNextStart
protected Traverser.Admin<S> processNextStart()
- Specified by:
processNextStartin classAbstractStep<S,S>
-
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 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 interfaceBarrier<S>- Returns:
- the next barrier of the step
- Throws:
NoSuchElementException
-
addBarrier
public 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 interfaceBarrier<S>- Parameters:
barrier- the barrier to merge in
-
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.
-
-