Class MergeElementStep<S,E,C>
- java.lang.Object
-
- org.apache.tinkerpop.gremlin.process.traversal.step.util.AbstractStep<S,E>
-
- org.apache.tinkerpop.gremlin.process.traversal.step.map.FlatMapStep<S,E>
-
- org.apache.tinkerpop.gremlin.process.traversal.step.map.MergeElementStep<S,E,C>
-
- All Implemented Interfaces:
Serializable,AutoCloseable,Cloneable,Iterator<Traverser.Admin<E>>,Step<S,E>,Deleting<Event>,MergeStepContract<S,E,C>,Mutating<Event>,PopContaining,PropertiesHolder,TraversalOptionParent<Merge,S,C>,TraversalParent,Writing<Event>
- Direct Known Subclasses:
MergeEdgeStep,MergeVertexStep
public abstract class MergeElementStep<S,E,C> extends FlatMapStep<S,E> implements MergeStepContract<S,E,C>
Abstract base class for themergeV/E()implementations.- See Also:
- Serialized Form
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface org.apache.tinkerpop.gremlin.process.traversal.step.PopContaining
PopContaining.PopInstruction
-
-
Field Summary
Fields Modifier and Type Field Description protected CallbackRegistry<Event>callbackRegistryprotected booleanfirstprotected booleanisStartprotected Traversal.Admin<S,Map>mergeTraversalprotected Traversal.Admin<S,Map>onCreateTraversalprotected Traversal.Admin<S,Map<String,?>>onMatchTraversalprotected booleanusesPartitionStrategy-
Fields inherited from class org.apache.tinkerpop.gremlin.process.traversal.step.util.AbstractStep
id, labels, nextEnd, nextStep, previousStep, starts, traversal, traverserStepIdAndLabelsSetByChild
-
Fields inherited from interface org.apache.tinkerpop.gremlin.process.traversal.step.map.MergeStepContract
CONCRETE_STEPS
-
-
Constructor Summary
Constructors Constructor Description MergeElementStep(Traversal.Admin traversal, boolean isStart)MergeElementStep(Traversal.Admin traversal, boolean isStart, Map mergeMap)MergeElementStep(Traversal.Admin traversal, boolean isStart, Traversal.Admin mergeTraversal)
-
Method Summary
All Methods Static Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description voidaddChildOption(Merge token, Traversal.Admin<S,C> traversalOption)voidaddProperty(Object key, Object value)This implementation should only be used as a mechanism for supportingPartitionStrategy.MergeElementStep<S,E,C>clone()Cloning is used to duplicate steps for the purpose of traversal optimization and OLTP replication.protected abstract Iterator<E>flatMap(Traverser.Admin<S> traverser)protected abstract SetgetAllowedTokens()CallbackRegistry<Event>getCallbackRegistry()protected GraphgetGraph()<S,C>
List<Traversal.Admin<S,C>>getLocalChildren()Gets a list of all "local" child traversals for this step.Traversal.Admin<S,Map>getMergeTraversal()Gets the traversal that will be used to provide theMapthat will be used to search for elements.CallbackRegistry<Event>getMutatingCallbackRegistry()Gets the callback registry for events that the step raises.Traversal.Admin<S,Map>getOnCreateTraversal()Gets the traversal that will be used to provide theMapthat will be used to create elements that do not match the search criteria ofgetMergeTraversal().Traversal.Admin<S,Map<String,?>>getOnMatchTraversal()Gets the traversal that will be used to provide theMapthat will be used to modify elements that match the search criteria ofgetMergeTraversal().Map<Object,List<Object>>getProperties()Set<TraverserRequirement>getRequirements()Provide the necessaryTraverserRequirementthat must be met by the traverser in order for the step to function properly.inthashCode()booleanisFirst()Determine if this is the first pass throughprocessNextStart().booleanisStart()Determines if this is a start step.booleanisUsingPartitionStrategy()protected MapmaterializeMap(Traverser.Admin<S> traverser, Traversal.Admin<S,?> mapTraversal)null Map == empty Mapprotected Traverser.Admin<E>processNextStart()booleanremoveProperty(Object k)voidreset()Reset the state of the step such that it has no incoming starts.protected CloseableIterator<Vertex>searchVertices(Map search)Translate the Map into a g.V() traversal against the supplied graph.protected GraphTraversalsearchVerticesLabelConstraint(GraphTraversal t, String label)protected GraphTraversalsearchVerticesPropertyConstraints(GraphTraversal t, Map search)protected GraphTraversalsearchVerticesTraversal(Graph graph, Object id)voidsetMerge(Traversal.Admin<?,Map<Object,Object>> mergeTraversal)voidsetOnCreate(Traversal.Admin<?,Map<Object,Object>> onCreateTraversal)voidsetOnMatch(Traversal.Admin<?,Map<Object,Object>> onMatchTraversal)voidsetTraversal(Traversal.Admin<?,?> parentTraversal)Set theTraversalthat this step is contained within.StringtoString()protected voidvalidate(Map map, boolean ignoreTokens)protected static voidvalidate(Map map, boolean ignoreTokens, Set allowedTokens, String op)protected voidvalidateNoOverrides(Map<?,?> mergeMap, Map<?,?> onCreateMap)Prohibit overrides to the existence criteria (id/label/from/to) in onCreate.-
Methods inherited from class org.apache.tinkerpop.gremlin.process.traversal.step.map.FlatMapStep
closeIterator
-
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 java.util.Iterator
forEachRemaining, remove
-
Methods inherited from interface org.apache.tinkerpop.gremlin.process.traversal.step.map.MergeStepContract
getMergeMapWithGValue, getOnCreateMapWithGValue, getOnMatchMapWithGValue
-
Methods inherited from interface org.apache.tinkerpop.gremlin.process.traversal.step.PropertiesHolder
getPropertiesWithGValues
-
Methods inherited from interface org.apache.tinkerpop.gremlin.process.traversal.step.TraversalParent
addGlobalChild, addLocalChild, asStep, close, getGlobalChildren, getPopInstructions, getSelfAndChildRequirements, integrateChild, removeGlobalChild, removeLocalChild, replaceLocalChild
-
-
-
-
Field Detail
-
isStart
protected final boolean isStart
-
first
protected boolean first
-
mergeTraversal
protected Traversal.Admin<S,Map> mergeTraversal
-
onCreateTraversal
protected Traversal.Admin<S,Map> onCreateTraversal
-
onMatchTraversal
protected Traversal.Admin<S,Map<String,?>> onMatchTraversal
-
callbackRegistry
protected CallbackRegistry<Event> callbackRegistry
-
usesPartitionStrategy
protected boolean usesPartitionStrategy
-
-
Constructor Detail
-
MergeElementStep
public MergeElementStep(Traversal.Admin traversal, boolean isStart)
-
MergeElementStep
public MergeElementStep(Traversal.Admin traversal, boolean isStart, Map mergeMap)
-
MergeElementStep
public MergeElementStep(Traversal.Admin traversal, boolean isStart, Traversal.Admin mergeTraversal)
-
-
Method Detail
-
getMergeTraversal
public Traversal.Admin<S,Map> getMergeTraversal()
Gets the traversal that will be used to provide theMapthat will be used to search for elements. ThisMapalso will be used as the default data set to be used to create the element if the search is not successful.- Specified by:
getMergeTraversalin interfaceMergeStepContract<S,E,C>
-
getOnCreateTraversal
public Traversal.Admin<S,Map> getOnCreateTraversal()
Gets the traversal that will be used to provide theMapthat will be used to create elements that do not match the search criteria ofgetMergeTraversal().- Specified by:
getOnCreateTraversalin interfaceMergeStepContract<S,E,C>
-
getOnMatchTraversal
public Traversal.Admin<S,Map<String,?>> getOnMatchTraversal()
Gets the traversal that will be used to provide theMapthat will be used to modify elements that match the search criteria ofgetMergeTraversal().- Specified by:
getOnMatchTraversalin interfaceMergeStepContract<S,E,C>
-
isStart
public boolean isStart()
Determines if this is a start step.- Specified by:
isStartin interfaceMergeStepContract<S,E,C>
-
isFirst
public boolean isFirst()
Determine if this is the first pass throughprocessNextStart().- Specified by:
isFirstin interfaceMergeStepContract<S,E,C>
-
getCallbackRegistry
public CallbackRegistry<Event> getCallbackRegistry()
-
addChildOption
public void addChildOption(Merge token, Traversal.Admin<S,C> traversalOption)
Description copied from interface:TraversalOptionParentThe child as defined by the token it takes, likePickorMerge. This traversal may be of local or global scope depending on the step implementation that works withoption().- Specified by:
addChildOptionin interfaceTraversalOptionParent<S,E,C>
-
getLocalChildren
public <S,C> List<Traversal.Admin<S,C>> getLocalChildren()
Description copied from interface:TraversalParentGets a list of all "local" child traversals for this step. A "local" traversal is one which is evaluated independently for each incoming traverser to the parent step. This is typically used in cases where the child is used to process or augment each traverser individually. SeeLocalSteporByModulatingas examples.- Specified by:
getLocalChildrenin interfaceTraversalParent
-
isUsingPartitionStrategy
public boolean isUsingPartitionStrategy()
- Specified by:
isUsingPartitionStrategyin interfaceMergeStepContract<S,E,C>
-
processNextStart
protected Traverser.Admin<E> processNextStart()
- Overrides:
processNextStartin classFlatMapStep<S,E>
-
getGraph
protected Graph getGraph()
-
getMutatingCallbackRegistry
public CallbackRegistry<Event> getMutatingCallbackRegistry()
Description copied from interface:MutatingGets the callback registry for events that the step raises.- Specified by:
getMutatingCallbackRegistryin interfaceMutating<S>
-
hashCode
public int hashCode()
- Overrides:
hashCodein classAbstractStep<S,E>
-
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.
-
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 interfaceMergeStepContract<S,E,C>- Specified by:
getRequirementsin interfaceStep<S,E>- Returns:
- the set of requirements
-
toString
public String toString()
- Overrides:
toStringin classAbstractStep<S,E>
-
setTraversal
public void setTraversal(Traversal.Admin<?,?> parentTraversal)
Description copied from interface:StepSet theTraversalthat this step is contained within.- Specified by:
setTraversalin interfaceStep<S,E>- Overrides:
setTraversalin classAbstractStep<S,E>- Parameters:
parentTraversal- the new traversal for this step
-
clone
public MergeElementStep<S,E,C> 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.
-
validate
protected void validate(Map map, boolean ignoreTokens)
-
validate
protected static void validate(Map map, boolean ignoreTokens, Set allowedTokens, String op)
-
validateNoOverrides
protected void validateNoOverrides(Map<?,?> mergeMap, Map<?,?> onCreateMap)
Prohibit overrides to the existence criteria (id/label/from/to) in onCreate.
-
materializeMap
protected Map materializeMap(Traverser.Admin<S> traverser, Traversal.Admin<S,?> mapTraversal)
null Map == empty Map
-
searchVertices
protected CloseableIterator<Vertex> searchVertices(Map search)
Translate the Map into a g.V() traversal against the supplied graph. Graph providers will presumably optimize this traversal to use whatever indices are present and appropriate for efficiency. Callers are responsible for closing this iterator when finished.
-
searchVerticesTraversal
protected GraphTraversal searchVerticesTraversal(Graph graph, Object id)
-
searchVerticesLabelConstraint
protected GraphTraversal searchVerticesLabelConstraint(GraphTraversal t, String label)
-
searchVerticesPropertyConstraints
protected GraphTraversal searchVerticesPropertyConstraints(GraphTraversal t, Map search)
-
flatMap
protected abstract Iterator<E> flatMap(Traverser.Admin<S> traverser)
- Specified by:
flatMapin classFlatMapStep<S,E>
-
getAllowedTokens
protected abstract Set getAllowedTokens()
-
setMerge
public void setMerge(Traversal.Admin<?,Map<Object,Object>> mergeTraversal)
- Specified by:
setMergein interfaceMergeStepContract<S,E,C>
-
setOnCreate
public void setOnCreate(Traversal.Admin<?,Map<Object,Object>> onCreateTraversal)
- Specified by:
setOnCreatein interfaceMergeStepContract<S,E,C>
-
setOnMatch
public void setOnMatch(Traversal.Admin<?,Map<Object,Object>> onMatchTraversal)
- Specified by:
setOnMatchin interfaceMergeStepContract<S,E,C>
-
addProperty
public void addProperty(Object key, Object value)
This implementation should only be used as a mechanism for supportingPartitionStrategy.- Specified by:
addPropertyin interfacePropertiesHolder
-
getProperties
public Map<Object,List<Object>> getProperties()
- Specified by:
getPropertiesin interfacePropertiesHolder
-
removeProperty
public boolean removeProperty(Object k)
- Specified by:
removePropertyin interfacePropertiesHolder
-
-