mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
DRY up and tweak style of the validation error object.
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@4213 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
This commit is contained in:
parent
32f66f09db
commit
37758cde13
1 changed files with 7 additions and 14 deletions
|
@ -97,13 +97,9 @@ module ActiveRecord
|
|||
# * Returns the error message, if one error is associated with the specified +attribute+.
|
||||
# * Returns an array of error messages, if more than one error is associated with the specified +attribute+.
|
||||
def on(attribute)
|
||||
if @errors[attribute.to_s].nil?
|
||||
nil
|
||||
elsif @errors[attribute.to_s].length == 1
|
||||
@errors[attribute.to_s].first
|
||||
else
|
||||
@errors[attribute.to_s]
|
||||
end
|
||||
errors = @errors[attribute.to_s]
|
||||
return nil if errors.nil?
|
||||
errors.size == 1 ? errors.first : errors
|
||||
end
|
||||
|
||||
alias :[] :on
|
||||
|
@ -139,13 +135,12 @@ module ActiveRecord
|
|||
end
|
||||
end
|
||||
end
|
||||
|
||||
return full_messages
|
||||
full_messages
|
||||
end
|
||||
|
||||
# Returns true if no errors have been added.
|
||||
def empty?
|
||||
return @errors.empty?
|
||||
@errors.empty?
|
||||
end
|
||||
|
||||
# Removes all the errors that have been added.
|
||||
|
@ -156,9 +151,7 @@ module ActiveRecord
|
|||
# Returns the total number of errors added. Two errors added to the same attribute will be counted as such
|
||||
# with this as well.
|
||||
def size
|
||||
error_count = 0
|
||||
@errors.each_value { |attribute| error_count += attribute.length }
|
||||
error_count
|
||||
@errors.values.inject(0) { |error_count, attribute| error_count + attribute.size }
|
||||
end
|
||||
|
||||
alias_method :count, :size
|
||||
|
|
Loading…
Reference in a new issue