Class GroupSideEffectStep<S,K,V>
- java.lang.Object
-
- org.apache.tinkerpop.gremlin.process.traversal.step.util.AbstractStep<S,S>
-
- org.apache.tinkerpop.gremlin.process.traversal.step.sideEffect.SideEffectStep<S>
-
- org.apache.tinkerpop.gremlin.process.traversal.step.sideEffect.GroupSideEffectStep<S,K,V>
-
- All Implemented Interfaces:
Serializable,AutoCloseable,Cloneable,Iterator<Traverser.Admin<S>>,Step<S,S>,ByModulating,Generating<Map<K,?>,Map<K,V>>,Grouping<S,K,V>,ProfilingAware,SideEffectCapable<Map<K,?>,Map<K,V>>,TraversalParent
public final class GroupSideEffectStep<S,K,V> extends SideEffectStep<S> implements SideEffectCapable<Map<K,?>,Map<K,V>>, TraversalParent, ByModulating, ProfilingAware, Grouping<S,K,V>
- Author:
- Marko A. Rodriguez (http://markorodriguez.com)
- See Also:
- Serialized Form
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface org.apache.tinkerpop.gremlin.process.traversal.step.ProfilingAware
ProfilingAware.ProfiledBarrier
-
-
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 GroupSideEffectStep(Traversal.Admin traversal, String sideEffectKey)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description GroupSideEffectStep<S,K,V>clone()Cloning is used to duplicate steps for the purpose of traversal optimization and OLTP replication.Map<K,V>generateFinalResult(Map<K,?> object)Post-process the side-effect and return the post-processed side-effect.Traversal.Admin<S,K>getKeyTraversal()Determines if the provided traversal is equal to the key traversal that theGroupinghas.List<Traversal.Admin<?,?>>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.Traversal.Admin<S,V>getValueTraversal()Determines if the provided traversal is equal to the value traversal that theGroupinghas.inthashCode()voidmodulateBy(Traversal.Admin<?,?> kvTraversal)voidprepareForProfiling()Reset theBarrieron the step to be wrapped in aProfilingAware.ProfiledBarrierwhich can properly start/stop the timer on the associatedProfileStep.voidreplaceLocalChild(Traversal.Admin<?,?> oldTraversal, Traversal.Admin<?,?> newTraversal)voidsetTraversal(Traversal.Admin<?,?> parentTraversal)Set theTraversalthat this step is contained within.protected voidsideEffect(Traverser.Admin<S> traverser)StringtoString()-
Methods inherited from class org.apache.tinkerpop.gremlin.process.traversal.step.sideEffect.SideEffectStep
processNextStart
-
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, reset, 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.Grouping
convertValueTraversal, determineBarrierStep, doFinalReduction, hasBarrierInValueTraversal
-
Methods inherited from interface java.util.Iterator
forEachRemaining, remove
-
Methods inherited from interface org.apache.tinkerpop.gremlin.process.traversal.step.TraversalParent
addGlobalChild, addLocalChild, asStep, close, getGlobalChildren, getSelfAndChildRequirements, integrateChild, removeGlobalChild, removeLocalChild
-
-
-
-
Constructor Detail
-
GroupSideEffectStep
public GroupSideEffectStep(Traversal.Admin traversal, String sideEffectKey)
-
-
Method Detail
-
prepareForProfiling
public void prepareForProfiling()
Reset theBarrieron the step to be wrapped in aProfilingAware.ProfiledBarrierwhich can properly start/stop the timer on the associatedProfileStep.- Specified by:
prepareForProfilingin interfaceProfilingAware
-
getKeyTraversal
public Traversal.Admin<S,K> getKeyTraversal()
Description copied from interface:GroupingDetermines if the provided traversal is equal to the key traversal that theGroupinghas.- Specified by:
getKeyTraversalin interfaceGrouping<S,K,V>
-
getValueTraversal
public Traversal.Admin<S,V> getValueTraversal()
Description copied from interface:GroupingDetermines if the provided traversal is equal to the value traversal that theGroupinghas.- Specified by:
getValueTraversalin interfaceGrouping<S,K,V>
-
modulateBy
public void modulateBy(Traversal.Admin<?,?> kvTraversal)
- Specified by:
modulateByin interfaceByModulating
-
replaceLocalChild
public void replaceLocalChild(Traversal.Admin<?,?> oldTraversal, Traversal.Admin<?,?> newTraversal)
- Specified by:
replaceLocalChildin interfaceTraversalParent
-
sideEffect
protected void sideEffect(Traverser.Admin<S> traverser)
- Specified by:
sideEffectin classSideEffectStep<S>
-
getSideEffectKey
public String getSideEffectKey()
Description copied from interface:SideEffectCapableThe side-effect key of the step.- Specified by:
getSideEffectKeyin interfaceSideEffectCapable<S,K>- Returns:
- the side-effect key
-
toString
public String toString()
- Overrides:
toStringin classAbstractStep<S,S>
-
getLocalChildren
public List<Traversal.Admin<?,?>> 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,K>- Returns:
- the set of requirements
-
clone
public GroupSideEffectStep<S,K,V> 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,K>- Overrides:
setTraversalin classAbstractStep<S,S>- Parameters:
parentTraversal- the new traversal for this step
-
hashCode
public int hashCode()
- Overrides:
hashCodein classAbstractStep<S,S>
-
generateFinalResult
public Map<K,V> generateFinalResult(Map<K,?> object)
Description copied from interface:GeneratingPost-process the side-effect and return the post-processed side-effect. The default implementation is simply the identity function and returns the argument.- Specified by:
generateFinalResultin interfaceGenerating<S,K>- Parameters:
object- the pre-processed side-effect.- Returns:
- the post-processed side-effect.
-
-