public class DefaultTraversalSideEffects extends Object implements TraversalSideEffects
TraversalSideEffects.Exceptions| Modifier and Type | Field and Description | 
|---|---|
| protected Map<String,Object> | objectMap | 
| protected Supplier | sackInitialValue | 
| protected BinaryOperator | sackMergeOperator | 
| protected UnaryOperator | sackSplitOperator | 
| protected Map<String,Supplier> | supplierMap | 
SIDE_EFFECTS| Constructor and Description | 
|---|
| DefaultTraversalSideEffects() | 
| Modifier and Type | Method and Description | 
|---|---|
| DefaultTraversalSideEffects | clone()Cloning is used to duplicate the sideEffects typically in OLAP environments. | 
| <V> Optional<V> | get(String key)Get the sideEffect associated with the provided key. | 
| <V> V | getOrCreate(String key,
           Supplier<V> orCreate)If the sideEffect contains an object associated with the key, return it. | 
| <V> Optional<Supplier<V>> | getRegisteredSupplier(String key)Get the registered  Supplierassociated with the specified key. | 
| <S> Supplier<S> | getSackInitialValue()If sacks are enabled, get the initial value of the  Traversersack. | 
| <S> BinaryOperator<S> | getSackMerger()If sacks are enabled and a merge function has been specified, then get it (else get  null). | 
| <S> UnaryOperator<S> | getSackSplitter()If sacks are enabled and a split operator has been specified, then get it (else get  null). | 
| Set<String> | keys()The keys of the sideEffect which includes registered  Supplierkeys. | 
| void | mergeInto(TraversalSideEffects sideEffects)Add the current  TraversalSideEffectsdata and suppliers to the providedTraversalSideEffects. | 
| void | registerSupplier(String key,
                Supplier supplier)Register a  Supplierwith the provided key. | 
| void | registerSupplierIfAbsent(String key,
                        Supplier supplier)A helper method to register a  Supplierif it has not already been registered. | 
| void | remove(String key)Remove both the value and registered  Supplierassociated with provided key. | 
| void | set(String key,
   Object value)Set the specified key to the specified value. | 
| void | setLocalVertex(Vertex vertex)In a distributed  GraphComputertraversal, the sideEffects of the traversal are not a single object within a single JVM. | 
| <S> void | setSack(Supplier<S> initialValue,
       UnaryOperator<S> splitOperator,
       BinaryOperator<S> mergeOperator)Set the initial value of each  Traverser"sack" along with the operators for splitting and merging sacks. | 
| String | toString() | 
equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitforEachprotected UnaryOperator sackSplitOperator
protected BinaryOperator sackMergeOperator
protected Supplier sackInitialValue
public void registerSupplier(String key, Supplier supplier)
Supplier with the provided key.
 When sideEffects get() are called, if no object exists and there exists a registered supplier for the key, the object is generated.
 Registered suppliers are used for the lazy generation of sideEffect data.registerSupplier in interface TraversalSideEffectskey - the key to register the supplier withsupplier - the supplier that will generate an object when get() is called if it hasn't already been createdpublic <V> Optional<Supplier<V>> getRegisteredSupplier(String key)
Supplier associated with the specified key.getRegisteredSupplier in interface TraversalSideEffectsV - The object type of the supplierkey - the key associated with the supplierpublic void registerSupplierIfAbsent(String key, Supplier supplier)
Supplier if it has not already been registered.registerSupplierIfAbsent in interface TraversalSideEffectskey - the key of the supplier to registersupplier - the supplier to register if the key has not already been registeredpublic <S> void setSack(Supplier<S> initialValue, UnaryOperator<S> splitOperator, BinaryOperator<S> mergeOperator)
TraversalSideEffectsTraverser "sack" along with the operators for splitting and merging sacks.
 If no split operator is provided, then a direct memory copy is assumed (this is typically good for primitive types and strings).
 If no merge operator is provided, then traversers with sacks will not be merged.setSack in interface TraversalSideEffectsS - the sack typeinitialValue - the initial value supplier of the traverser sacksplitOperator - the split operator for splitting traverser sacksmergeOperator - the merge operator for merging traverser sackspublic <S> Supplier<S> getSackInitialValue()
TraversalSideEffectsTraverser sack.
 If its not enabled, then null is returned.getSackInitialValue in interface TraversalSideEffectsS - the sack typepublic <S> UnaryOperator<S> getSackSplitter()
TraversalSideEffectsnull).
 The split operator is used to split a sack when a bifurcation in a Traverser happens.getSackSplitter in interface TraversalSideEffectsS - the sack typepublic <S> BinaryOperator<S> getSackMerger()
TraversalSideEffectsnull).
 The merge function is used to merge two sacks when two Traversers converge.getSackMerger in interface TraversalSideEffectsS - the sack typepublic void set(String key, Object value)
Supplier is provided, it is NOT assumed to be a supplier as set by registerSupplier().set in interface TraversalSideEffectskey - the keyvalue - the valuepublic <V> Optional<V> get(String key) throws IllegalArgumentException
Optional.
 Else if the sideEffect has a registered Supplier for that key, generate the object, store the object in the sideEffects, and return it.get in interface TraversalSideEffectsV - the type of the value to retrievekey - the key to get the value forIllegalArgumentException - if the key does not reference an object or a registered supplier.public <V> V getOrCreate(String key, Supplier<V> orCreate)
Supplier.getOrCreate in interface TraversalSideEffectsV - the return type of the objectkey - the key of the object to getorCreate - if the object doesn't exist as an object or suppliable object, then generate it with the specified supplierpublic void remove(String key)
Supplier associated with provided key.remove in interface TraversalSideEffectskey - the key of the value and registered supplier to removepublic Set<String> keys()
Supplier keys.
 In essence, that which is possible to get().keys in interface TraversalSideEffectspublic void setLocalVertex(Vertex vertex)
GraphComputer traversal, the sideEffects of the traversal are not a single object within a single JVM.
 Instead, the sideEffects are distributed across the graph and the pieces are stored on the computing vertices.
 This method is necessary to call when the Traversal is processing the Traversers at a particular Vertex.setLocalVertex in interface TraversalSideEffectsvertex - the vertex where the traversal is currently executing.public void mergeInto(TraversalSideEffects sideEffects)
TraversalSideEffectsTraversalSideEffects data and suppliers to the provided TraversalSideEffects.mergeInto in interface TraversalSideEffectssideEffects - the sideEffects to add this traversal's sideEffect data to.public DefaultTraversalSideEffects clone()
TraversalSideEffectsclone in interface TraversalSideEffectsclone in class ObjectCopyright © 2013–2015 Apache Software Foundation. All rights reserved.