Class SupplyingBarrierStep<S,​E>

    • Constructor Detail

      • SupplyingBarrierStep

        public SupplyingBarrierStep​(Traversal.Admin traversal)
    • Method Detail

      • supply

        protected abstract E supply()
      • reset

        public void reset()
        Description copied from interface: Step
        Reset 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.
        Specified by:
        reset in interface Step<S,​E>
        Overrides:
        reset in class AbstractStep<S,​E>
      • clone

        public SupplyingBarrierStep<S,​E> clone()
        Description copied from interface: Step
        Cloning 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 when Step.reset() is called. Moreover, the previous and next steps should be set to EmptyStep.
        Specified by:
        clone in interface Step<S,​E>
        Overrides:
        clone in class AbstractStep<S,​E>
        Returns:
        The cloned step
      • processAllStarts

        public void processAllStarts()
        Description copied from interface: Barrier
        Process all left traversers by do not yield the resultant output. This method is useful for steps like ReducingBarrierStep, where traversers can be processed "on the fly" and thus, reduce memory consumption.
        Specified by:
        processAllStarts in interface Barrier<S>
      • hasNextBarrier

        public boolean hasNextBarrier()
        Description copied from interface: Barrier
        Whether or not the step has an accessible barrier.
        Specified by:
        hasNextBarrier in interface Barrier<S>
        Returns:
        whether a barrier exists or not
      • addBarrier

        public void addBarrier​(Boolean barrier)
        Description copied from interface: Barrier
        Add a barrier to the step. This typically happens when multiple parallel barriers need to become one barrier at a single step.
        Specified by:
        addBarrier in interface Barrier<S>
        Parameters:
        barrier - the barrier to merge in
      • done

        public void done()
        Description copied from interface: Barrier
        A way to hard set that the barrier is complete. This is necessary when parallel barriers don't all have barriers and need hard resetting. The default implementation does nothing.
        Specified by:
        done in interface Barrier<S>