Sha256: 77522c1cfac5106f4f98af1dc2ddd4e068dc473a064c160e5f3fd1d52ec342eb
Contents?: true
Size: 1.92 KB
Versions: 6
Compression:
Stored size: 1.92 KB
Contents
# frozen_string_literal: true require "dry/core/equalizer" require "dry/logic/operators" module Dry module Schema # Predicate objects used within the DSL # # @api public class Predicate # A negated predicate # # @api private class Negation include Dry::Logic::Operators # @api private attr_reader :predicate # @api private def initialize(predicate) @predicate = predicate end # Dump negated predicate to an AST # # @return [Array] # # @api private def to_ast(*args) [:not, predicate.to_ast(*args)] end alias_method :ast, :to_ast end include Dry::Logic::Operators include Dry::Equalizer(:name, :args, :block) # @api private attr_reader :compiler # @api private attr_reader :name # @api private attr_reader :args # @api private attr_reader :block # @api private def initialize(compiler, name, args, block) @compiler = compiler @name = name @args = args @block = block end # Negate a predicate # # @example # required(:name).value(:string) { !empty? } # # @return [Negation] # # @api public def ! Negation.new(self) end # @api private def ensure_valid if compiler.predicates[name].arity - 1 != args.size raise ArgumentError, "#{name} predicate arity is invalid" end end # Compile predicate to a rule object # # @api private def to_rule compiler.visit(to_ast) end # Dump predicate to an AST # # @return [Array] # # @api private def to_ast(*) [:predicate, [name, compiler.predicates.arg_list(name, *args)]] end alias_method :ast, :to_ast end end end
Version data entries
6 entries across 6 versions & 1 rubygems