public final class GroupSideEffectStep<S,K,V> extends SideEffectStep<S> implements SideEffectCapable<Map<K,?>,Map<K,V>>, TraversalParent, ByModulating, ProfilingAware, Grouping<S,K,V>
ProfilingAware.ProfiledBarrier
id, labels, nextEnd, nextStep, previousStep, starts, traversal, traverserStepIdAndLabelsSetByChild
Constructor and Description |
---|
GroupSideEffectStep(Traversal.Admin traversal,
String sideEffectKey) |
Modifier and Type | Method and 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 the
Grouping has. |
List<Traversal.Admin<?,?>> |
getLocalChildren() |
Set<TraverserRequirement> |
getRequirements()
Provide the necessary
TraverserRequirement 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 the
Grouping has. |
int |
hashCode() |
void |
modulateBy(Traversal.Admin<?,?> kvTraversal) |
void |
prepareForProfiling()
Reset the
Barrier on the step to be wrapped in a ProfilingAware.ProfiledBarrier which can
properly start/stop the timer on the associated ProfileStep . |
void |
replaceLocalChild(Traversal.Admin<?,?> oldTraversal,
Traversal.Admin<?,?> newTraversal) |
void |
setTraversal(Traversal.Admin<?,?> parentTraversal)
Set the
Traversal that this step is contained within. |
protected void |
sideEffect(Traverser.Admin<S> traverser) |
String |
toString() |
processNextStart
addLabel, addStart, addStarts, equals, getId, getLabels, getNextStep, getPreviousStep, getStarts, getTraversal, hasNext, hasStarts, isTraverserStepIdAndLabelsSetByChild, next, prepareTraversalForNextStep, removeLabel, reset, setId, setNextStep, setPreviousStep
finalize, getClass, notify, notifyAll, wait, wait, wait
addGlobalChild, addLocalChild, asStep, close, getGlobalChildren, getSelfAndChildRequirements, integrateChild, removeGlobalChild, removeLocalChild
modulateBy, modulateBy, modulateBy, modulateBy, modulateBy, modulateBy, modulateBy, modulateBy, modulateBy, modulateBy, modulateBy
convertValueTraversal, determineBarrierStep, doFinalReduction
forEachRemaining, remove
public GroupSideEffectStep(Traversal.Admin traversal, String sideEffectKey)
public void prepareForProfiling()
Barrier
on the step to be wrapped in a ProfilingAware.ProfiledBarrier
which can
properly start/stop the timer on the associated ProfileStep
.prepareForProfiling
in interface ProfilingAware
public Traversal.Admin<S,K> getKeyTraversal()
Grouping
Grouping
has.getKeyTraversal
in interface Grouping<S,K,V>
public Traversal.Admin<S,V> getValueTraversal()
Grouping
Grouping
has.getValueTraversal
in interface Grouping<S,K,V>
public void modulateBy(Traversal.Admin<?,?> kvTraversal)
modulateBy
in interface ByModulating
public void replaceLocalChild(Traversal.Admin<?,?> oldTraversal, Traversal.Admin<?,?> newTraversal)
replaceLocalChild
in interface TraversalParent
protected void sideEffect(Traverser.Admin<S> traverser)
sideEffect
in class SideEffectStep<S>
public String getSideEffectKey()
SideEffectCapable
getSideEffectKey
in interface SideEffectCapable<Map<K,?>,Map<K,V>>
public String toString()
toString
in class AbstractStep<S,S>
public List<Traversal.Admin<?,?>> getLocalChildren()
getLocalChildren
in interface TraversalParent
public Set<TraverserRequirement> getRequirements()
Step
TraverserRequirement
that must be met by the traverser in order for the step to
function properly. The provided default implements returns an empty set.getRequirements
in interface Step<S,S>
public GroupSideEffectStep<S,K,V> clone()
Step
Step.reset()
is called. Moreover, the previous and next steps should be set to EmptyStep
.public void setTraversal(Traversal.Admin<?,?> parentTraversal)
Step
Traversal
that this step is contained within.setTraversal
in interface Step<S,S>
setTraversal
in class AbstractStep<S,S>
parentTraversal
- the new traversal for this steppublic int hashCode()
hashCode
in class AbstractStep<S,S>
public Map<K,V> generateFinalResult(Map<K,?> object)
Generating
generateFinalResult
in interface Generating<Map<K,?>,Map<K,V>>
object
- the pre-processed side-effect.Copyright © 2013–2021 Apache Software Foundation. All rights reserved.