Class: Concurrent::Promises::AbstractEventFuture
- Inherits:
- 
      Synchronization::Object
      
        - Object
- Synchronization::Object
- Concurrent::Promises::AbstractEventFuture
 
- Includes:
- ThrottleIntegration
- Defined in:
- lib/concurrent/promises.rb,
 lib-edge/concurrent/edge/throttle.rb
Overview
Defined Under Namespace
Modules: ThrottleIntegration
Instance Method Summary collapse
- 
  
    
      #chain(*args, &task)  ⇒ Future 
    
    
  
  
  
  
  
  
  
  
  
    Shortcut of #chain_on with default :ioexecutor supplied.
- 
  
    
      #chain_on(executor, *args, &task)  ⇒ Future 
    
    
  
  
  
  
  
  
  
  
  
    Chains the task to be executed asynchronously on executor after it is resolved. 
- 
  
    
      #chain_resolvable(resolvable)  ⇒ self 
    
    
      (also: #tangle)
    
  
  
  
  
  
  
  
  
  
    Resolves the resolvable when receiver is resolved. 
- 
  
    
      #chain_throttled_by(throttle, *args, &block)  ⇒ Future, Event 
    
    
  
  
    
      included
      from ThrottleIntegration
    
  
  
  
  
  
  
  
  
    Behaves as #chain but the it is throttled. 
- 
  
    
      #default_executor  ⇒ Executor 
    
    
  
  
  
  
  
  
  
  
  
    Returns default executor. 
- 
  
    
      #on_resolution(*args, &callback)  ⇒ self 
    
    
  
  
  
  
  
  
  
  
  
    Shortcut of #on_resolution_using with default :ioexecutor supplied.
- 
  
    
      #on_resolution!(*args, &callback)  ⇒ self 
    
    
  
  
  
  
  
  
  
  
  
    Stores the callback to be executed synchronously on resolving thread after it is resolved. 
- 
  
    
      #on_resolution_using(executor, *args, &callback)  ⇒ self 
    
    
  
  
  
  
  
  
  
  
  
    Stores the callback to be executed asynchronously on executor after it is resolved. 
- 
  
    
      #pending?  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    Is it in pending state?. 
- 
  
    
      #resolved?  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    Is it in resolved state?. 
- 
  
    
      #state  ⇒ Symbol 
    
    
  
  
  
  
  
  
  
  
  
    Returns its state. 
- #throttled_by(throttle) {|a| ... } ⇒ Future, Event included from ThrottleIntegration
- 
  
    
      #to_s  ⇒ String 
    
    
      (also: #inspect)
    
  
  
  
  
  
  
  
  
  
    Short string representation. 
- 
  
    
      #touch  ⇒ self 
    
    
  
  
  
  
  
  
  
  
  
    Propagates touch. 
- 
  
    
      #wait(timeout = nil)  ⇒ Future, true, false 
    
    
  
  
  
  
  
  
  
  
  
    Wait (block the Thread) until receiver is #resolved?. 
- 
  
    
      #with_default_executor(executor)  ⇒ AbstractEventFuture 
    
    
  
  
  
  
  
  abstract
  
  
  
    Crates new object with same class with the executor set as its new default executor. 
Instance Method Details
#chain(*args, &task) ⇒ Future
Shortcut of #chain_on with default :io executor supplied.
| 576 577 578 | # File 'lib/concurrent/promises.rb', line 576 def chain(*args, &task) chain_on @DefaultExecutor, *args, &task end | 
#an_event.chain_on(executor, *args) {|*args| ... } ⇒ Future #a_future.chain_on(executor, *args) {|fulfilled, value, reason, *args| ... } ⇒ Future
Chains the task to be executed asynchronously on executor after it is resolved.
| 594 595 596 | # File 'lib/concurrent/promises.rb', line 594 def chain_on(executor, *args, &task) ChainPromise.new_blocked_by1(self, @DefaultExecutor, executor, args, &task).future end | 
#chain_resolvable(resolvable) ⇒ self Also known as: tangle
Resolves the resolvable when receiver is resolved.
| 609 610 611 | # File 'lib/concurrent/promises.rb', line 609 def chain_resolvable(resolvable) on_resolution! { resolvable.resolve_with internal_state } end | 
#chain_throttled_by(throttle, *args, &block) ⇒ Future, Event Originally defined in module ThrottleIntegration
Behaves as Concurrent::Promises::AbstractEventFuture#chain but the it is throttled.
#default_executor ⇒ Executor
Returns default executor.
| 570 571 572 | # File 'lib/concurrent/promises.rb', line 570 def default_executor @DefaultExecutor end | 
#on_resolution(*args, &callback) ⇒ self
Shortcut of #on_resolution_using with default :io executor supplied.
| 617 618 619 | # File 'lib/concurrent/promises.rb', line 617 def on_resolution(*args, &callback) on_resolution_using @DefaultExecutor, *args, &callback end | 
#an_event.on_resolution!(*args) {|*args| ... } ⇒ self #a_future.on_resolution!(*args) {|fulfilled, value, reason, *args| ... } ⇒ self
Stores the callback to be executed synchronously on resolving thread after it is resolved.
| 635 636 637 | # File 'lib/concurrent/promises.rb', line 635 def on_resolution!(*args, &callback) add_callback :callback_on_resolution, args, callback end | 
#an_event.on_resolution_using(executor, *args) {|*args| ... } ⇒ self #a_future.on_resolution_using(executor, *args) {|fulfilled, value, reason, *args| ... } ⇒ self
Stores the callback to be executed asynchronously on executor after it is resolved.
| 653 654 655 | # File 'lib/concurrent/promises.rb', line 653 def on_resolution_using(executor, *args, &callback) add_callback :async_callback_on_resolution, executor, args, callback end | 
#pending? ⇒ Boolean
Is it in pending state?
| 529 530 531 | # File 'lib/concurrent/promises.rb', line 529 def pending? !internal_state.resolved? end | 
#resolved? ⇒ Boolean
Is it in resolved state?
| 535 536 537 | # File 'lib/concurrent/promises.rb', line 535 def resolved? internal_state.resolved? end | 
#an_event.state ⇒ :pending, :resolved #a_future.state ⇒ :pending, :fulfilled, :rejected
Returns its state.
| 523 524 525 | # File 'lib/concurrent/promises.rb', line 523 def state internal_state.to_sym end | 
#throttled_by(throttle) {|a| ... } ⇒ Future, Event Originally defined in module ThrottleIntegration
#to_s ⇒ String Also known as: inspect
Returns Short string representation.
| 599 600 601 | # File 'lib/concurrent/promises.rb', line 599 def to_s format '%s %s>', super[0..-2], state end | 
#touch ⇒ self
Propagates touch. Requests all the delayed futures, which it depends on, to be executed. This method is called by any other method requiring resolved state, like #wait.
| 542 543 544 545 | # File 'lib/concurrent/promises.rb', line 542 def touch @Promise.touch self end | 
#wait(timeout = nil) ⇒ Future, true, false
This function potentially blocks current thread until the Future is resolved. Be careful it can deadlock. Try to chain instead.
Wait (block the Thread) until receiver is #resolved?. Calls #touch.
| 558 559 560 561 | # File 'lib/concurrent/promises.rb', line 558 def wait(timeout = nil) result = wait_until_resolved(timeout) timeout ? result : self end | 
#with_default_executor(executor) ⇒ AbstractEventFuture
Crates new object with same class with the executor set as its new default executor. Any futures depending on it will use the new default executor.
| 663 664 665 | # File 'lib/concurrent/promises.rb', line 663 def with_default_executor(executor) raise NotImplementedError end |