Sha256: 01e82af771a6485a70ebfb8a43864458750f233678571deab489e4890f2827bf

Contents?: true

Size: 1.54 KB

Versions: 340

Compression:

Stored size: 1.54 KB

Contents

require 'concurrent/executor/immediate_executor'
require 'concurrent/executor/simple_executor_service'

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 = SimpleExecutorService.new
    end

    # @!macro executor_service_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
  end
end

Version data entries

340 entries across 309 versions & 62 rubygems

Version Path
concurrent-ruby-0.9.2-java lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-0.9.2 lib/concurrent/executor/indirect_immediate_executor.rb
logstash-input-beats-0.9.2 vendor/jruby/1.9/gems/concurrent-ruby-0.9.1-java/lib/concurrent/executor/indirect_immediate_executor.rb
logstash-input-beats-0.9.1 vendor/jruby/1.9/gems/concurrent-ruby-0.9.1-java/lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-1.0.0.pre4-java lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-1.0.0.pre4 lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-1.0.0.pre3-java lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-1.0.0.pre3 lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-1.0.0.pre2-java lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-1.0.0.pre2 lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-1.0.0.pre1 lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-1.0.0.pre1-java lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-0.9.1 lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-0.9.1-java lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-0.9.0 lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-0.9.0-java lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-0.9.0.pre3-java lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-0.9.0.pre3 lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-0.9.0.pre2 lib/concurrent/executor/indirect_immediate_executor.rb
concurrent-ruby-0.9.0.pre2-java lib/concurrent/executor/indirect_immediate_executor.rb