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