Sha256: 40f5d5b2cedc629d257a6bb7191e357af8beaac7847eb22b410e4ec589713d48
Contents?: true
Size: 1.89 KB
Versions: 1
Compression:
Stored size: 1.89 KB
Contents
module Sequel class Model # Errors represents validation errors, a simple hash subclass # with a few convenience methods. class Errors < ::Hash ATTRIBUTE_JOINER = ' and '.freeze # Assign an array of messages for each attribute on access. # Using this message is discouraged in new code, use +add+ # to add new error messages, and +on+ to check existing # error messages. def [](k) if has_key?(k) super else Sequel::Deprecation.deprecate('Model::Errors#[] autovivification', 'Please switch to Model::Errors#add to add errors, and Model::Errors#on to get errors') self[k] = [] end end # Adds an error for the given attribute. # # errors.add(:name, 'is not valid') if name == 'invalid' def add(att, msg) fetch(att){self[att] = []} << msg end # Return the total number of error messages. # # errors.count # => 3 def count values.inject(0){|m, v| m + v.length} end # Return true if there are no error messages, false otherwise. def empty? count == 0 end # Returns an array of fully-formatted error messages. # # errors.full_messages # # => ['name is not valid', # # 'hometown is not at least 2 letters'] def full_messages inject([]) do |m, kv| att, errors = *kv errors.each {|e| m << (e.is_a?(LiteralString) ? e : "#{Array(att).join(ATTRIBUTE_JOINER)} #{e}")} m end end # Returns the array of errors for the given attribute, or nil # if there are no errors for the attribute. # # errors.on(:name) # => ['name is not valid'] # errors.on(:id) # => nil def on(att) if v = fetch(att, nil) and !v.empty? v end end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
sequel-3.48.0 | lib/sequel/model/errors.rb |