Sha256: f2c33da53d9f56ecbfe866711e4d9c029aaeaebdd54b9609e197eab1ab385080

Contents?: true

Size: 1.29 KB

Versions: 68

Compression:

Stored size: 1.29 KB

Contents

# frozen_string_literal: true

module Mutant
  module Parallel
    # Job source for parallel execution
    class Source
      include AbstractType

      class Job
        include Adamantium, Anima.new(:index, :payload)
      end

      NoJobError = Class.new(RuntimeError)

      # Next job
      #
      # @return [Object]
      #
      # @raise [NoJobError]
      #   when no next job is available
      abstract_method :next

      # Test if next job is available
      #
      # @return [Boolean]
      abstract_method :next?

      # Job source backed by a finite array
      class Array
        include Concord.new(:jobs)

        # Initialize objecto
        #
        # @return [undefined]
        def initialize(*)
          super

          @next_index = 0
        end

        # Test if next job is available
        #
        # @return [Boolean]
        def next?
          @next_index < jobs.length
        end

        # Next job
        #
        # @return [Job]
        #
        # @raise [NoJobError]
        #   when no next job is available
        def next
          fail NoJobError unless next?
          Job.new(index: @next_index, payload: jobs.fetch(@next_index)).tap do
            @next_index += 1
          end
        end

      end # Array
    end # Source
  end # Parallel
end # Mutant

Version data entries

68 entries across 68 versions & 1 rubygems

Version Path
mutant-0.11.18 lib/mutant/parallel/source.rb
mutant-0.11.17 lib/mutant/parallel/source.rb
mutant-0.11.16 lib/mutant/parallel/source.rb
mutant-0.11.15 lib/mutant/parallel/source.rb
mutant-0.11.14 lib/mutant/parallel/source.rb
mutant-0.11.13 lib/mutant/parallel/source.rb
mutant-0.11.12 lib/mutant/parallel/source.rb
mutant-0.11.11 lib/mutant/parallel/source.rb
mutant-0.11.10 lib/mutant/parallel/source.rb
mutant-0.11.9 lib/mutant/parallel/source.rb
mutant-0.11.8 lib/mutant/parallel/source.rb
mutant-0.11.7 lib/mutant/parallel/source.rb
mutant-0.11.6 lib/mutant/parallel/source.rb
mutant-0.11.5 lib/mutant/parallel/source.rb
mutant-0.11.4 lib/mutant/parallel/source.rb
mutant-0.11.3 lib/mutant/parallel/source.rb
mutant-0.11.2 lib/mutant/parallel/source.rb
mutant-0.11.1 lib/mutant/parallel/source.rb
mutant-0.11.0 lib/mutant/parallel/source.rb
mutant-0.10.35 lib/mutant/parallel/source.rb