Class MergeStep<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.MergeStep<S,E,C>
-
- All Implemented Interfaces:
Serializable,AutoCloseable,Cloneable,Iterator<Traverser.Admin<E>>,Step<S,E>,Configuring,Deleting<Event>,Mutating<Event>,Parameterizing,TraversalOptionParent<Merge,S,C>,TraversalParent,Writing<Event>
- Direct Known Subclasses:
MergeEdgeStep,MergeVertexStep
public abstract class MergeStep<S,E,C> extends FlatMapStep<S,E> implements Writing<Event>, Deleting<Event>, TraversalOptionParent<Merge,S,C>
Abstract base class for themergeV/E()implementations.- See Also:
- Serialized Form
-
-
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,?>>onMatchTraversal-
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 MergeStep(Traversal.Admin traversal, boolean isStart)MergeStep(Traversal.Admin traversal, boolean isStart, Map mergeMap)MergeStep(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)MergeStep<S,E,C>clone()Cloning is used to duplicate steps for the purpose of traversal optimization and OLTP replication.voidconfigure(Object... keyValues)Accept a configuration to theStep.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()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().ParametersgetParameters()Gets the parameters on the step.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.protected MapmaterializeMap(Traverser.Admin<S> traverser, Traversal.Admin<S,?> mapTraversal)null Map == empty Mapprotected Traverser.Admin<E>processNextStart()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)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.TraversalParent
addGlobalChild, addLocalChild, asStep, close, getGlobalChildren, 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
-
-
Constructor Detail
-
MergeStep
public MergeStep(Traversal.Admin traversal, boolean isStart)
-
MergeStep
public MergeStep(Traversal.Admin traversal, boolean isStart, Map mergeMap)
-
MergeStep
public MergeStep(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.
-
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().
-
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().
-
isStart
public boolean isStart()
Determines if this is a start step.
-
isFirst
public boolean isFirst()
Determine if this is the first pass throughprocessNextStart().
-
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()
- Specified by:
getLocalChildrenin interfaceTraversalParent
-
configure
public void configure(Object... keyValues)
Description copied from interface:ConfiguringAccept a configuration to theStep. Note that this interface extendsParameterizingand so there is an expectation that theStepimplementation will have aParametersinstance that will house any values passed to this method. Storing these configurations inParametersis not a requirement however, IF the configuration is an expected option for the step and can be stored on a member field that can be accessed on the step by more direct means (i.e. like a getter method).- Specified by:
configurein interfaceConfiguring
-
getParameters
public Parameters getParameters()
Description copied from interface:ParameterizingGets the parameters on the step.- Specified by:
getParametersin interfaceParameterizing
-
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 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 MergeStep<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()
-
-