Sha256: 5b60d9b6457a0b5bdad623f940a853fade4d483698a7c9ac15befcc486d5335d
Contents?: true
Size: 1.26 KB
Versions: 5
Compression:
Stored size: 1.26 KB
Contents
# encoding: utf-8 module Mixture module Types # An object. This adds the basic constraints all types (that # inherit from Object) have; i.e., it must be an object, and # it must be the type's primitive. class Object < Type options[:primitive] = ::Object options[:method] = :to_object as :object # This, like {Type.inheritable}, provides a list of inheritable # coercions; however, by default, if the requesting type isn't # an Object, it _also_ leaves out the Object type; this is so # that types that are incompatible with another type all the way # up to the Object don't end up getting coerced incorrectly. # # @return [Array<Class>] def self.inheritable if self == Object super else ancestors - Object.ancestors end end constraint do |value| # This may seem a bit odd, but this returns false for # BasicObject; and since this is meant to represent Objects, # we want to make sure that the value isn't a BasicObject. # rubocop:disable Style/CaseEquality ::Object === value # rubocop:enable Style/CaseEquality end constraint { |value| value.is_a?(options[:primitive]) } end end end
Version data entries
5 entries across 5 versions & 1 rubygems