Sha256: 416465dd3f00f33cc683a4c300d47786d35c9d1ea53d738cdc55ec97de2ba708

Contents?: true

Size: 1.21 KB

Versions: 16

Compression:

Stored size: 1.21 KB

Contents

# frozen_string_literal: true

require 'thread'

module Nanoc::Extra
  # @api private
  class ParallelCollection
    STOP = Object.new

    include Nanoc::Int::ContractsSupport

    contract C::RespondTo[:each], C::KeywordArgs[parallelism: Integer] => C::Any
    def initialize(enum, parallelism: 2)
      @enum = enum
      @parallelism = parallelism
    end

    contract C::Func[C::Any => C::Any] => self
    def each
      queue = SizedQueue.new(2 * @parallelism)
      error = nil

      threads = (1..@parallelism).map do
        Thread.new do
          loop do
            begin
              elem = queue.pop
              break if error
              break if STOP.equal?(elem)
              yield elem
            rescue => err
              error = err
              break
            end
          end
        end
      end

      @enum.each { |e| queue << e }
      @parallelism.times { queue << STOP }

      threads.each(&:join)

      raise error if error
      self
    end

    contract C::Func[C::Any => C::Any] => C::RespondTo[:each]
    def map
      [].tap do |all|
        mutex = Mutex.new
        each do |e|
          res = yield(e)
          mutex.synchronize { all << res }
        end
      end
    end
  end
end

Version data entries

16 entries across 16 versions & 1 rubygems

Version Path
nanoc-4.8.10 lib/nanoc/extra/parallel_collection.rb
nanoc-4.8.9 lib/nanoc/extra/parallel_collection.rb
nanoc-4.8.8 lib/nanoc/extra/parallel_collection.rb
nanoc-4.8.7 lib/nanoc/extra/parallel_collection.rb
nanoc-4.8.6 lib/nanoc/extra/parallel_collection.rb
nanoc-4.8.5 lib/nanoc/extra/parallel_collection.rb
nanoc-4.8.4 lib/nanoc/extra/parallel_collection.rb
nanoc-4.8.3 lib/nanoc/extra/parallel_collection.rb
nanoc-4.8.2 lib/nanoc/extra/parallel_collection.rb
nanoc-4.8.1 lib/nanoc/extra/parallel_collection.rb
nanoc-4.8.0 lib/nanoc/extra/parallel_collection.rb
nanoc-4.7.14 lib/nanoc/extra/parallel_collection.rb
nanoc-4.7.13 lib/nanoc/extra/parallel_collection.rb
nanoc-4.7.12 lib/nanoc/extra/parallel_collection.rb
nanoc-4.7.11 lib/nanoc/extra/parallel_collection.rb
nanoc-4.7.10 lib/nanoc/extra/parallel_collection.rb