Sha256: de9d7fbd795abd14e352538d33700d5428b8a268c5187a3e341b170e204c8fc2
Contents?: true
Size: 1.65 KB
Versions: 1
Compression:
Stored size: 1.65 KB
Contents
module Whenner # A promise represents the public face of a {Deferred} object. You can use it # to add more callbacks to the deferred or inspect its state -- but you # cannot resolve it. # # The methods and attributes of the promise are basically forwarded to the # deferred. class Promise extend Forwardable # @!attribute [r] fulfilled? # @return [Boolean] whether the deferred was successfully resolved. # @!attribute [r] resolved? # @return [Boolean] whether the deferred was either fulfilled or rejected. # @!attribute [r] rejected? # @return [Boolean] whether the deferred was rejected. # @!attribute [r] pending? # @return [Boolean] whether the deferred has not been resolved yet. # @!attribute [r] reason # @return [Object] the reason for the deferred to be rejected. # @!attribute [r] value # @return [Object] the value that the deferred was fulfilled with. # @!method fail(&block) # Register a callback to fire when the deferred is rejected. # @return [Promise] a new promise for the return value of the block. # @!method done(&block) # Register a callback to fire when the deferred is fulfilled. # @return [Promise] a new promise for the return value of the block. # @!method always(&block) # Register a callback to fire when the deferred is resolved. # @return [Promise] a new promise for the return value of the block. def_delegators :@deferred, *%i[ reason value pending? fulfilled? resolved? rejected? fail done always ] def initialize(deferred) @deferred = deferred end def to_promise self end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
whenner-0.1.1 | lib/whenner/promise.rb |