aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/active_record/validations.rb
diff options
context:
space:
mode:
Diffstat (limited to 'activerecord/lib/active_record/validations.rb')
-rw-r--r--activerecord/lib/active_record/validations.rb53
1 files changed, 22 insertions, 31 deletions
diff --git a/activerecord/lib/active_record/validations.rb b/activerecord/lib/active_record/validations.rb
index 55c4236874..be64e00bd1 100644
--- a/activerecord/lib/active_record/validations.rb
+++ b/activerecord/lib/active_record/validations.rb
@@ -36,49 +36,40 @@ module ActiveRecord
# The validation process on save can be skipped by passing false. The regular Base#save method is
# replaced with this when the validations module is mixed in, which it is by default.
- def save(options=nil)
- return super if valid?(options)
- false
- end
-
- def save_without_validation!
- save!(:validate => false)
+ def save(options={})
+ perform_validations(options) ? super : false
end
# Attempts to save the record just like Base#save but will raise a RecordInvalid exception instead of returning false
# if the record is not valid.
- def save!(options = nil)
- return super if valid?(options)
- raise RecordInvalid.new(self)
+ def save!(options={})
+ perform_validations(options) ? super : raise(RecordInvalid.new(self))
end
# Runs all the specified validations and returns true if no errors were added otherwise false.
- def valid?(options = nil)
- perform_validation = case options
- when NilClass
- true
- when Hash
- options[:validate] != false
- else
- ActiveSupport::Deprecation.warn "save(#{options}) is deprecated, please give save(:validate => #{options}) instead", caller
- options
- end
+ def valid?(context = nil)
+ context ||= (new_record? ? :create : :update)
+ super(context)
- if perform_validation
- errors.clear
+ deprecated_callback_method(:validate)
+ deprecated_callback_method(:"validate_on_#{context}")
- self.validation_context = new_record? ? :create : :update
- _run_validate_callbacks
+ errors.empty?
+ end
- deprecated_callback_method(:validate)
+ protected
- if new_record?
- deprecated_callback_method(:validate_on_create)
- else
- deprecated_callback_method(:validate_on_update)
- end
+ def perform_validations(options={})
+ perform_validation = case options
+ when Hash
+ options[:validate] != false
+ else
+ ActiveSupport::Deprecation.warn "save(#{options}) is deprecated, please give save(:validate => #{options}) instead", caller
+ options
+ end
- errors.empty?
+ if perform_validation
+ valid?(options.is_a?(Hash) ? options[:context] : nil)
else
true
end