diff options
| -rw-r--r-- | activerecord/lib/active_record/persistence.rb | 12 | ||||
| -rw-r--r-- | activerecord/lib/active_record/validations.rb | 15 | 
2 files changed, 12 insertions, 15 deletions
| diff --git a/activerecord/lib/active_record/persistence.rb b/activerecord/lib/active_record/persistence.rb index 96e44c2f59..f35865f54c 100644 --- a/activerecord/lib/active_record/persistence.rb +++ b/activerecord/lib/active_record/persistence.rb @@ -36,6 +36,18 @@ module ActiveRecord          end        end +      # Creates an object just like Base.create but calls <tt>save!</tt> instead of +save+ +      # so an exception is raised if the record is invalid. +      def create!(attributes = nil, &block) +        if attributes.is_a?(Array) +          attributes.collect { |attr| create!(attr, &block) } +        else +          object = new(attributes, &block) +          object.save! +          object +        end +      end +        # Given an attributes hash, +instantiate+ returns a new instance of        # the appropriate class. Accepts only keys as strings.        # diff --git a/activerecord/lib/active_record/validations.rb b/activerecord/lib/active_record/validations.rb index b4b33804de..7f7d49cdb4 100644 --- a/activerecord/lib/active_record/validations.rb +++ b/activerecord/lib/active_record/validations.rb @@ -29,21 +29,6 @@ module ActiveRecord      extend ActiveSupport::Concern      include ActiveModel::Validations -    module ClassMethods -      # Creates an object just like Base.create but calls <tt>save!</tt> instead of +save+ -      # so an exception is raised if the record is invalid. -      def create!(attributes = nil, &block) -        if attributes.is_a?(Array) -          attributes.collect { |attr| create!(attr, &block) } -        else -          object = new(attributes) -          yield(object) if block_given? -          object.save! -          object -        end -      end -    end -      # The validation process on save can be skipped by passing <tt>validate: false</tt>.      # The regular Base#save method is replaced with this when the validations      # module is mixed in, which it is by default. | 
