Sha256: 8d7f565f069fa18235f9dc86d9f6f5fadfd607aa291fb74844a8a4692ce9dc90
Contents?: true
Size: 1.77 KB
Versions: 2
Compression:
Stored size: 1.77 KB
Contents
require 'dry/types/decorator' require 'dry/types/constraints' require 'dry/types/constrained/coercible' module Dry module Types class Constrained include Dry::Equalizer(:type, :options, :rule) include Decorator include Builder # @return [Dry::Logic::Rule] attr_reader :rule # @param [Definition] type # @param [Hash] options def initialize(type, options) super @rule = options.fetch(:rule) end # @param [Object] input # @return [Object] # @raise [ConstraintError] def call(input) try(input) do |result| raise ConstraintError.new(result, input) end.input end alias_method :[], :call # @param [Object] input # @param [#call] block # @yieldparam [Failure] failure # @yieldreturn [Result] # @return [Result] def try(input, &block) result = rule.(input) if result.success? type.try(input, &block) else failure = failure(input, result) block ? yield(failure) : failure end end # @param [Object] value # @return [Boolean] def valid?(value) rule.(value).success? && type.valid?(value) end # @param [Hash] options # The options hash provided to {Types.Rule} and combined # using {&} with previous {#rule} # @return [Constrained] # @see Dry::Logic::Operators#and def constrained(options) with(rule: rule & Types.Rule(options)) end # @return [true] def constrained? true end private # @param [Object] response # @return [Boolean] def decorate?(response) super || response.kind_of?(Constructor) end end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
dry-types-0.9.4 | lib/dry/types/constrained.rb |
dry-types-0.9.3 | lib/dry/types/constrained.rb |