Class DedupGlobalStep<S>
- java.lang.Object
-
- org.apache.tinkerpop.gremlin.process.traversal.step.util.AbstractStep<S,S>
-
- org.apache.tinkerpop.gremlin.process.traversal.step.filter.FilterStep<S>
-
- org.apache.tinkerpop.gremlin.process.traversal.step.filter.DedupGlobalStep<S>
-
- All Implemented Interfaces:
Serializable,AutoCloseable,Cloneable,Iterator<Traverser.Admin<S>>,Step<S,S>,Barrier<Map<Object,Traverser.Admin<S>>>,ByModulating,GraphComputing,MemoryComputing<Map<Object,Traverser.Admin<S>>>,PathProcessor,PopContaining,Scoping,TraversalParent
public final class DedupGlobalStep<S> extends FilterStep<S> implements TraversalParent, Scoping, GraphComputing, Barrier<Map<Object,Traverser.Admin<S>>>, ByModulating, PathProcessor
- 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.PathProcessor
PathProcessor.ElementRequirement
-
Nested classes/interfaces inherited from interface org.apache.tinkerpop.gremlin.process.traversal.step.PopContaining
PopContaining.PopInstruction
-
Nested classes/interfaces inherited from interface org.apache.tinkerpop.gremlin.process.traversal.step.Scoping
Scoping.KeyNotFoundException, Scoping.Variable
-
-
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 DedupGlobalStep(Traversal.Admin traversal, String... dedupLabels)
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddBarrier(Map<Object,Traverser.Admin<S>> barrier)Add a barrier to the step.voidatMaster(boolean atMaster)Some steps should behave different whether they are executing at the master traversal or distributed across the worker traversals.DedupGlobalStep<S>clone()Cloning is used to duplicate steps for the purpose of traversal optimization and OLTP replication.protected booleanfilter(Traverser.Admin<S> traverser)Set<String>getKeepLabels()List<Traversal<S,Object>>getLocalChildren()PathProcessor.ElementRequirementgetMaxRequirement()MemoryComputeKey<Map<Object,Traverser.Admin<S>>>getMemoryComputeKey()TheMemoryComputeKeythat will be used by this step.HashSet<PopContaining.PopInstruction>getPopInstructions()Used to get PopInstruction of a Step that implements Scoping.Set<TraverserRequirement>getRequirements()Provide the necessaryTraverserRequirementthat must be met by the traverser in order for the step to function properly.Set<String>getScopeKeys()Get the labels that this scoping step will access during the traversalinthashCode()booleanhasNextBarrier()Whether or not the step has an accessible barrier.voidmodulateBy(Traversal.Admin<?,?> dedupTraversal)Map<Object,Traverser.Admin<S>>nextBarrier()Get the next barrier within this step.voidonGraphComputer()The step will be executing on aGraphComputer.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.voidsetKeepLabels(Set<String> keepLabels)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 java.util.Iterator
forEachRemaining, remove
-
Methods inherited from interface org.apache.tinkerpop.gremlin.process.traversal.step.Scoping
getNullableScopeValue, getSafeScopeValue, getScopeValue
-
Methods inherited from interface org.apache.tinkerpop.gremlin.process.traversal.step.TraversalParent
addGlobalChild, addLocalChild, asStep, close, getGlobalChildren, getSelfAndChildRequirements, integrateChild, removeGlobalChild, removeLocalChild
-
-
-
-
Constructor Detail
-
DedupGlobalStep
public DedupGlobalStep(Traversal.Admin traversal, String... dedupLabels)
-
-
Method Detail
-
filter
protected boolean filter(Traverser.Admin<S> traverser)
- Specified by:
filterin classFilterStep<S>
-
atMaster
public void atMaster(boolean atMaster)
Description copied from interface:GraphComputingSome steps should behave different whether they are executing at the master traversal or distributed across the worker traversals. The default implementation does nothing.- Specified by:
atMasterin interfaceGraphComputing- Parameters:
atMaster- whether the step is currently executing at master
-
getMaxRequirement
public PathProcessor.ElementRequirement getMaxRequirement()
- Specified by:
getMaxRequirementin interfacePathProcessor
-
processNextStart
protected Traverser.Admin<S> processNextStart()
- Overrides:
processNextStartin classFilterStep<S>
-
getLocalChildren
public List<Traversal<S,Object>> getLocalChildren()
- Specified by:
getLocalChildrenin interfaceTraversalParent
-
modulateBy
public void modulateBy(Traversal.Admin<?,?> dedupTraversal)
- Specified by:
modulateByin interfaceByModulating
-
replaceLocalChild
public void replaceLocalChild(Traversal.Admin<?,?> oldTraversal, Traversal.Admin<?,?> newTraversal)
- Specified by:
replaceLocalChildin interfaceTraversalParent
-
clone
public DedupGlobalStep<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>
-
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.
-
toString
public String toString()
- Overrides:
toStringin classAbstractStep<S,S>
-
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
-
onGraphComputer
public void onGraphComputer()
Description copied from interface:GraphComputingThe step will be executing on aGraphComputer.- Specified by:
onGraphComputerin interfaceGraphComputing
-
getScopeKeys
public Set<String> getScopeKeys()
Description copied from interface:ScopingGet the labels that this scoping step will access during the traversal- Specified by:
getScopeKeysin interfaceScoping- Returns:
- the accessed labels of the scoping step
-
getPopInstructions
public HashSet<PopContaining.PopInstruction> getPopInstructions()
Description copied from interface:ScopingUsed to get PopInstruction of a Step that implements Scoping. PopInstruction includes the labels it needs, and the pop type for each label.- Specified by:
getPopInstructionsin interfacePopContaining- Specified by:
getPopInstructionsin interfaceScoping- Specified by:
getPopInstructionsin interfaceTraversalParent- Returns:
- A Set of
PopContaining.PopInstructionvalues which contain the label and Pop value
-
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 Map<Object,Traverser.Admin<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(Map<Object,Traverser.Admin<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
-
getMemoryComputeKey
public MemoryComputeKey<Map<Object,Traverser.Admin<S>>> getMemoryComputeKey()
Description copied from interface:MemoryComputingTheMemoryComputeKeythat will be used by this step.- Specified by:
getMemoryComputeKeyin interfaceMemoryComputing<S>- Returns:
- the MemoryComputeKey to use
-
setKeepLabels
public void setKeepLabels(Set<String> keepLabels)
- Specified by:
setKeepLabelsin interfacePathProcessor
-
getKeepLabels
public Set<String> getKeepLabels()
- Specified by:
getKeepLabelsin interfacePathProcessor
-
-