public class DefaultTraversal<S,E> extends Object implements Traversal.Admin<S,E>
Traversal.Admin<S,E>, Traversal.Exceptions, Traversal.Symbols| Modifier and Type | Field and Description | 
|---|---|
| protected Bytecode | bytecode | 
| protected boolean | closed | 
| protected TraversalSource | g | 
| protected TraverserGenerator | generator | 
| protected Graph | graph | 
| protected boolean | locked | 
| protected TraversalParent | parent | 
| protected Set<TraverserRequirement> | requirements | 
| protected TraversalSideEffects | sideEffects | 
| protected List<Step> | steps | 
| protected TraversalStrategies | strategies | 
| protected List<Step> | unmodifiableSteps | 
| Constructor and Description | 
|---|
| DefaultTraversal() | 
| DefaultTraversal(Bytecode bytecode) | 
| DefaultTraversal(Graph graph) | 
| DefaultTraversal(TraversalSource traversalSource) | 
| DefaultTraversal(TraversalSource traversalSource,
                Traversal.Admin<S,E> traversal) | 
| Modifier and Type | Method and Description | 
|---|---|
| void | addStart(Traverser.Admin<S> start)Add a single  Traverser.Adminobject to the head of the traversal. | 
| void | addStarts(Iterator<Traverser.Admin<S>> starts)Add an iterator of  Traverser.Adminobjects to the head/start of the traversal. | 
| <S2,E2> Traversal.Admin<S2,E2> | addStep(int index,
       Step<?,?> step)Add a  Stepto an arbitrary point in the traversal. | 
| void | applyStrategies()Apply the registered  TraversalStrategiesto the traversal. | 
| Traversal.Admin<S,E> | asAdmin()Get access to administrative methods of the traversal via its accompanying  Traversal.Admin. | 
| DefaultTraversal<S,E> | clone()Cloning is used to duplicate the traversal typically in OLAP environments. | 
| boolean | equals(Object other) | 
| Bytecode | getBytecode()Get the  Bytecodeassociated with the construction of this traversal. | 
| Step<?,E> | getEndStep()Get the end/tail of the traversal. | 
| Optional<Graph> | getGraph() | 
| TraversalParent | getParent()Get the  TraversalParentStepthat is the parent of this traversal. | 
| TraversalSideEffects | getSideEffects()Get the  TraversalSideEffectsassociated with the traversal. | 
| Step<S,?> | getStartStep()Get the start/head of the traversal. | 
| List<Step> | getSteps()Get the  Stepinstances associated with this traversal. | 
| TraversalStrategies | getStrategies()Get the  TraversalStrategiesassociated with this traversal. | 
| Optional<TraversalSource> | getTraversalSource()Gets the  TraversalSourcethat spawned theTraversalinstance initially if present. | 
| TraverserGenerator | getTraverserGenerator()Get the  TraverserGeneratorassociated with this traversal. | 
| Set<TraverserRequirement> | getTraverserRequirements()Get the set of all  TraverserRequirements for this traversal. | 
| int | hashCode() | 
| boolean | hasNext() | 
| boolean | isClosed()Determines if the traversal has been fully iterated and resources released. | 
| boolean | isLocked()When the traversal has had its  TraversalStrategiesapplied to it, it is locked. | 
| E | next() | 
| Traverser.Admin<E> | nextTraverser() | 
| void | notifyClose()Gets a callback from  Traversal.close()for additional operations specific to theTraversalimplementation. | 
| <S2,E2> Traversal.Admin<S2,E2> | removeStep(int index)Remove a  Stepfrom the traversal. | 
| void | reset()Call the  Step.reset()method on every step in the traversal. | 
| void | setGraph(Graph graph) | 
| void | setParent(TraversalParent step)Set the  TraversalParentStepthat is the parent of this traversal. | 
| void | setSideEffects(TraversalSideEffects sideEffects)Set the  TraversalSideEffectsof this traversal. | 
| void | setStrategies(TraversalStrategies strategies)Set the  TraversalStrategiesto be used by this traversal at evaluation time. | 
| String | toString() | 
finalize, getClass, notify, notifyAll, wait, wait, waitaddStep, equals, getTraverserSetSupplier, isRoot, removeStepprotected transient Graph graph
protected transient TraversalSource g
protected TraversalParent parent
protected TraversalSideEffects sideEffects
protected TraversalStrategies strategies
protected transient TraverserGenerator generator
protected Set<TraverserRequirement> requirements
protected boolean locked
protected boolean closed
protected Bytecode bytecode
public DefaultTraversal(Graph graph)
public DefaultTraversal(TraversalSource traversalSource)
public DefaultTraversal(TraversalSource traversalSource, Traversal.Admin<S,E> traversal)
public DefaultTraversal()
public DefaultTraversal(Bytecode bytecode)
public Bytecode getBytecode()
Traversal.AdminBytecode associated with the construction of this traversal.getBytecode in interface Traversal.Admin<S,E>public Traversal.Admin<S,E> asAdmin()
TraversalTraversal.Admin.public TraverserGenerator getTraverserGenerator()
Traversal.AdminTraverserGenerator associated with this traversal.
 The traversal generator creates Traverser instances that are respective of the traversal's
 TraverserRequirement.getTraverserGenerator in interface Traversal.Admin<S,E>public void applyStrategies()
                     throws IllegalStateException
Traversal.AdminTraversalStrategies to the traversal.
 Once the strategies are applied, the traversal is "locked" and can no longer have steps added to it.
 The order of operations for strategy applications should be: globally id steps, apply each strategy in turn
 to root traversal, then recursively to nested traversals.applyStrategies in interface Traversal.Admin<S,E>IllegalStateException - if the TraversalStrategies have already been appliedpublic Set<TraverserRequirement> getTraverserRequirements()
Traversal.AdminTraverserRequirements for this traversal.getTraverserRequirements in interface Traversal.Admin<S,E>public List<Step> getSteps()
Traversal.AdminStep instances associated with this traversal.
 The steps are ordered according to their linked list structure as defined by Step.getPreviousStep() and Step.getNextStep().getSteps in interface Traversal.Admin<S,E>public Traverser.Admin<E> nextTraverser()
nextTraverser in interface Traversal.Admin<S,E>public void reset()
Traversal.AdminStep.reset() method on every step in the traversal.reset in interface Traversal.Admin<S,E>public void addStart(Traverser.Admin<S> start)
Traversal.AdminTraverser.Admin object to the head of the traversal. Users should typically not need
 to call this method. For dynamic inject of data, they should use InjectStep.addStart in interface Traversal.Admin<S,E>start - a traverser to add to the traversalpublic void addStarts(Iterator<Traverser.Admin<S>> starts)
Traversal.AdminTraverser.Admin objects to the head/start of the traversal. Users should
 typically not need to call this method. For dynamic inject of data, they should use InjectStep.addStarts in interface Traversal.Admin<S,E>starts - an iterators of traverserspublic Step<S,?> getStartStep()
Traversal.AdminEmptyStep instance is returned.getStartStep in interface Traversal.Admin<S,E>public Step<?,E> getEndStep()
Traversal.AdminEmptyStep instance is returned.getEndStep in interface Traversal.Admin<S,E>public DefaultTraversal<S,E> clone()
Traversal.Adminpublic boolean isLocked()
Traversal.AdminTraversalStrategies applied to it, it is locked.isLocked in interface Traversal.Admin<S,E>public boolean isClosed()
public void notifyClose()
TraversalTraversal.close() for additional operations specific to the Traversal implementation.
 A good implementation will use Traversal.close() to release resources in steps and this method to release
 resources specific to the Traversal implementations.notifyClose in interface Traversal<S,E>public void setSideEffects(TraversalSideEffects sideEffects)
Traversal.AdminTraversalSideEffects of this traversal.setSideEffects in interface Traversal.Admin<S,E>sideEffects - the sideEffects to set for this traversal.public TraversalSideEffects getSideEffects()
Traversal.AdminTraversalSideEffects associated with the traversal. This method should not be called
 externally for purposes of retrieving side-effects as traversal results. Traversal results should only be
 returned by way of the execution of the traversal itself. Should a side-effect of a traversal be needed it
 should only be obtained by using GraphTraversal.cap(String, String...) so that the side-effect can
 be included as part of the traversal iteration. Relying on this method to get side-effects in these
 situations may not result in consistent behavior across all types of executions and environments (e.g.
 remoting).getSideEffects in interface Traversal.Admin<S,E>public void setStrategies(TraversalStrategies strategies)
Traversal.AdminTraversalStrategies to be used by this traversal at evaluation time.setStrategies in interface Traversal.Admin<S,E>strategies - the strategies to use on this traversalpublic TraversalStrategies getStrategies()
Traversal.AdminTraversalStrategies associated with this traversal.getStrategies in interface Traversal.Admin<S,E>public <S2,E2> Traversal.Admin<S2,E2> addStep(int index, Step<?,?> step) throws IllegalStateException
Traversal.AdminStep to an arbitrary point in the traversal.addStep in interface Traversal.Admin<S,E>S2 - the new start type of the traversal (if the added step was a start step)E2 - the new end type of the traversal (if the added step was an end step)index - the location in the traversal to insert the stepstep - the step to addIllegalStateException - if the TraversalStrategies have already been appliedpublic <S2,E2> Traversal.Admin<S2,E2> removeStep(int index) throws IllegalStateException
Traversal.AdminStep from the traversal.removeStep in interface Traversal.Admin<S,E>S2 - the new start type of the traversal (if the removed step was a start step)E2 - the new end type of the traversal (if the removed step was an end step)index - the location in the traversal of the step to be evictedIllegalStateException - if the TraversalStrategies have already been appliedpublic void setParent(TraversalParent step)
Traversal.AdminTraversalParent Step that is the parent of this traversal. Traversals can be nested
 and this is the means by which the traversal tree is connected. If there is no parent, then it should be a
 EmptyStep.setParent in interface Traversal.Admin<S,E>step - the traversal holder parent step or EmptyStep if it has no parentpublic TraversalParent getParent()
Traversal.AdminTraversalParent Step that is the parent of this traversal. Traversals can be nested
 and this is the means by which the traversal tree is walked.getParent in interface Traversal.Admin<S,E>EmptyStep if it has no parent.public Optional<Graph> getGraph()
Traversal.AdmingetGraph in interface Traversal.Admin<S,E>public Optional<TraversalSource> getTraversalSource()
Traversal.AdminTraversalSource that spawned the Traversal instance initially if present. This
 TraversalSource should have spawned from the associated Graph returned from
 Traversal.Admin.getGraph().getTraversalSource in interface Traversal.Admin<S,E>public void setGraph(Graph graph)
setGraph in interface Traversal.Admin<S,E>Copyright © 2013–2022 Apache Software Foundation. All rights reserved.