Sha256: ac250887157f4f755f1da412c8f30fab85bafc4bc269487c7f3e6f18f5f3f0f1

Contents?: true

Size: 1.51 KB

Versions: 7

Compression:

Stored size: 1.51 KB

Contents

require 'concurrent/executor/executor'

module Concurrent
  # An executor service which runs all operations on a new thread, blocking
  # until it completes. Operations are performed in the order they are received
  # and no two operations can be performed simultaneously.
  #
  # This executor service exists mainly for testing an debugging. When used it
  # immediately runs every `#post` operation on a new thread, blocking the
  # current thread until the operation is complete. This is similar to how the
  # ImmediateExecutor works, but the operation has the full stack of the new
  # thread at its disposal. This can be helpful when the operations will spawn
  # more operations on the same executor and so on - such a situation might
  # overflow the single stack in case of an ImmediateExecutor, which is
  # inconsistent with how it would behave for a threaded executor.
  #
  # @note Intended for use primarily in testing and debugging.
  class IndirectImmediateExecutor < ImmediateExecutor
    # Creates a new executor
    def initialize
      super
      @internal_executor = PerThreadExecutor.new
    end

    # @!macro executor_method_post
    def post(*args, &task)
      raise ArgumentError.new("no block given") unless block_given?
      return false unless running?

      event = Concurrent::Event.new
      internal_executor.post do
        begin
          task.call(*args)
        ensure
          event.set
        end
      end
      event.wait

      true
    end

    private
    attr_reader :internal_executor
  end
end

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
concurrent-ruby-0.7.1 lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-0.7.1-x86_64-linux lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-0.7.1-x86-solaris-2.11 lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-0.7.1-x86-mingw32 lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-0.7.1-x86-linux lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-0.7.1-x64-mingw32 lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-0.7.1-java lib/concurrent/executor/indirect_immediate_executor.rb