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 theGrouping
has.List<Traversal.Admin<?,?>>
getLocalChildren()
Set<TraverserRequirement>
getRequirements()
Provide the necessaryTraverserRequirement
that must be met by the traverser in order for the step to function properly.String
getSideEffectKey()
The side-effect key of the step.Traversal.Admin<S,V>
getValueTraversal()
Determines if the provided traversal is equal to the value traversal that theGrouping
has.int
hashCode()
void
modulateBy(Traversal.Admin<?,?> kvTraversal)
void
prepareForProfiling()
Reset theBarrier
on the step to be wrapped in aProfilingAware.ProfiledBarrier
which can properly start/stop the timer on the associatedProfileStep
.void
replaceLocalChild(Traversal.Admin<?,?> oldTraversal, Traversal.Admin<?,?> newTraversal)
void
setTraversal(Traversal.Admin<?,?> parentTraversal)
Set theTraversal
that this step is contained within.protected void
sideEffect(Traverser.Admin<S> traverser)
String
toString()
-
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 theBarrier
on the step to be wrapped in aProfilingAware.ProfiledBarrier
which can properly start/stop the timer on the associatedProfileStep
.- Specified by:
prepareForProfiling
in interfaceProfilingAware
-
getKeyTraversal
public Traversal.Admin<S,K> getKeyTraversal()
Description copied from interface:Grouping
Determines if the provided traversal is equal to the key traversal that theGrouping
has.- Specified by:
getKeyTraversal
in interfaceGrouping<S,K,V>
-
getValueTraversal
public Traversal.Admin<S,V> getValueTraversal()
Description copied from interface:Grouping
Determines if the provided traversal is equal to the value traversal that theGrouping
has.- Specified by:
getValueTraversal
in interfaceGrouping<S,K,V>
-
modulateBy
public void modulateBy(Traversal.Admin<?,?> kvTraversal)
- Specified by:
modulateBy
in interfaceByModulating
-
replaceLocalChild
public void replaceLocalChild(Traversal.Admin<?,?> oldTraversal, Traversal.Admin<?,?> newTraversal)
- Specified by:
replaceLocalChild
in interfaceTraversalParent
-
sideEffect
protected void sideEffect(Traverser.Admin<S> traverser)
- Specified by:
sideEffect
in classSideEffectStep<S>
-
getSideEffectKey
public String getSideEffectKey()
Description copied from interface:SideEffectCapable
The side-effect key of the step.- Specified by:
getSideEffectKey
in interfaceSideEffectCapable<S,K>
- Returns:
- the side-effect key
-
toString
public String toString()
- Overrides:
toString
in classAbstractStep<S,S>
-
getLocalChildren
public List<Traversal.Admin<?,?>> getLocalChildren()
- Specified by:
getLocalChildren
in interfaceTraversalParent
-
getRequirements
public Set<TraverserRequirement> getRequirements()
Description copied from interface:Step
Provide the necessaryTraverserRequirement
that must be met by the traverser in order for the step to function properly. The provided default implements returns an empty set.- Specified by:
getRequirements
in interfaceStep<S,K>
- Returns:
- the set of requirements
-
clone
public GroupSideEffectStep<S,K,V> clone()
Description copied from interface:Step
Cloning 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:Step
Set theTraversal
that this step is contained within.- Specified by:
setTraversal
in interfaceStep<S,K>
- Overrides:
setTraversal
in classAbstractStep<S,S>
- Parameters:
parentTraversal
- the new traversal for this step
-
hashCode
public int hashCode()
- Overrides:
hashCode
in classAbstractStep<S,S>
-
generateFinalResult
public Map<K,V> generateFinalResult(Map<K,?> object)
Description copied from interface:Generating
Post-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:
generateFinalResult
in interfaceGenerating<S,K>
- Parameters:
object
- the pre-processed side-effect.- Returns:
- the post-processed side-effect.
-
-