public interface TraversalSideEffects extends Cloneable, Serializable, AutoCloseable
Traversal can maintain global sideEffects.
 Unlike Traverser "sacks" which are local sideEffects, TraversalSideEffects are accessible by all Traverser instances within the Traversal.| Modifier and Type | Interface and Description | 
|---|---|
| static class  | TraversalSideEffects.Exceptions | 
| Modifier and Type | Method and Description | 
|---|---|
| void | add(String key,
   Object value)Add a value to the global side-effect value. | 
| TraversalSideEffects | clone()Cloning is used to duplicate the sideEffects typically in distributed execution environments. | 
| default void | close()Invalidate the side effect cache for traversal. | 
| default boolean | exists(String key)Return true if the key is a registered side-effect. | 
| default <V> void | forEach(BiConsumer<String,V> biConsumer) | 
| <V> V | get(String key)Get the sideEffect associated with the provided key. | 
| <V> BinaryOperator<V> | getReducer(String key)Get the reducer associated with the side-effect 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). | 
| <V> Supplier<V> | getSupplier(String key)Get the supplier associated with the side-effect key. | 
| default boolean | isEmpty()Determines if there are any side-effects to be retrieved. | 
| Set<String> | keys()The keys of the sideEffect which includes registered  Supplierkeys. | 
| void | mergeInto(TraversalSideEffects sideEffects)Add the current  TraversalSideEffectsvalues, suppliers, and reducers to the providedTraversalSideEffects. | 
| <V> void | register(String key,
        Supplier<V> initialValue,
        BinaryOperator<V> reducer) | 
| <V> void | registerIfAbsent(String key,
                Supplier<V> initialValue,
                BinaryOperator<V> reducer) | 
| 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. | 
| <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. | 
default boolean exists(String key)
key - the key to check for existence<V> V get(String key) throws IllegalArgumentException
Supplier for that key, generate the object, store the object in the sideEffects, and return it.V - 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.void set(String key, Object value) throws IllegalArgumentException
add(String, Object).
 This method is only safe when there is only one representation of the side-effect and thus, not distributed across threads or machines.key - the key they key of the side-effectvalue - the value the new value for the side-effectIllegalArgumentException - if the key does not reference a registered side-effect.void remove(String key)
Supplier associated with provided key.key - the key of the value and registered supplier to removeSet<String> keys()
Supplier keys.
 In essence, that which is possible to get().default void close()
            throws Exception
close in interface AutoCloseableExceptiondefault boolean isEmpty()
<V> void register(String key, Supplier<V> initialValue, BinaryOperator<V> reducer)
TraversalSideEffects providing a Supplier and a BinaryOperator.
 If a null value is provided for the supplier or reducer, then it no supplier or reducer is registered.V - the type of the side-effect valuekey - the key of the side-effect valueinitialValue - the initial value supplierreducer - the reducer to use for merging a distributed side-effect value into a single value<V> void registerIfAbsent(String key, Supplier<V> initialValue, BinaryOperator<V> reducer)
TraversalSideEffects providing a Supplier and a BinaryOperator.
 The registration will only overwrite a supplier or reducer if no supplier or reducer existed prior.
 If a null value is provided for the supplier or reducer, then it no supplier or reducer is registered.V - the type of the side-effect valuekey - the key of the side-effect valueinitialValue - the initial value supplierreducer - the reducer to use for merging a distributed side-effect value into a single value<V> BinaryOperator<V> getReducer(String key) throws IllegalArgumentException
Operator.assign is provided.V - the type of the side-effect valuekey - the key of the side-effectIllegalArgumentException - if no side-effect exists for the provided key<V> Supplier<V> getSupplier(String key) throws IllegalArgumentException
ConstantSupplier is provided.V - the type of the side-effect valuekey - the key of the side-effectIllegalArgumentException - if no side-effect exists for the provided keyvoid add(String key, Object value) throws IllegalArgumentException
set(String, Object)  should only be used in single-threaded systems or by a master traversal in a distributed environment.key - the key of the side-effect.value - the partital value (to be merged) of the side-effect.IllegalArgumentException - if no side-effect exists for the provided key<S> void setSack(Supplier<S> initialValue, UnaryOperator<S> splitOperator, BinaryOperator<S> mergeOperator)
Traverser "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.S - the sack typeinitialValue - the initial value supplier of the traverser sacksplitOperator - the split operator for splitting traverser sacksmergeOperator - the merge operator for merging traverser sacks<S> Supplier<S> getSackInitialValue()
Traverser sack.
 If its not enabled, then null is returned.S - the sack type<S> UnaryOperator<S> getSackSplitter()
null).
 The split operator is used to split a sack when a bifurcation in a Traverser happens.S - the sack type<S> BinaryOperator<S> getSackMerger()
null).
 The merge function is used to merge two sacks when two Traversers converge.S - the sack typedefault <V> void forEach(BiConsumer<String,V> biConsumer)
TraversalSideEffects clone()
void mergeInto(TraversalSideEffects sideEffects)
TraversalSideEffects values, suppliers, and reducers to the provided TraversalSideEffects.
 The implementation should (under the hood), use registerIfAbsent(String, Supplier, BinaryOperator) so that
 if the argument TraversalSideEffects already has a registered supplier or binary operator, then don't overwrite it.sideEffects - the sideEffects to add this traversal's sideEffect data to.Copyright © 2013–2018 Apache Software Foundation. All rights reserved.