aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib
diff options
context:
space:
mode:
authorJeremy Kemper <jeremy@bitsweat.net>2008-03-31 01:49:57 +0000
committerJeremy Kemper <jeremy@bitsweat.net>2008-03-31 01:49:57 +0000
commit97019f9f5a94fa102debe13f5a957726e7d4783e (patch)
tree7887d896653681930192d6735712858a2ec903ea /activerecord/lib
parent3aaf60def848785a9c9c05c426359fa69888ef13 (diff)
downloadrails-97019f9f5a94fa102debe13f5a957726e7d4783e.tar.gz
rails-97019f9f5a94fa102debe13f5a957726e7d4783e.tar.bz2
rails-97019f9f5a94fa102debe13f5a957726e7d4783e.zip
Partial updates play nice with updated_at/on timestamps
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@9159 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'activerecord/lib')
-rwxr-xr-xactiverecord/lib/active_record.rb4
-rw-r--r--activerecord/lib/active_record/timestamp.rb2
2 files changed, 3 insertions, 3 deletions
diff --git a/activerecord/lib/active_record.rb b/activerecord/lib/active_record.rb
index 3fc40291ba..8b274120df 100755
--- a/activerecord/lib/active_record.rb
+++ b/activerecord/lib/active_record.rb
@@ -62,6 +62,8 @@ ActiveRecord::Base.class_eval do
include ActiveRecord::Validations
include ActiveRecord::Locking::Optimistic
include ActiveRecord::Locking::Pessimistic
+ include ActiveRecord::AttributeMethods
+ include ActiveRecord::Dirty
include ActiveRecord::Callbacks
include ActiveRecord::Observing
include ActiveRecord::Timestamp
@@ -73,8 +75,6 @@ ActiveRecord::Base.class_eval do
include ActiveRecord::Reflection
include ActiveRecord::Calculations
include ActiveRecord::Serialization
- include ActiveRecord::AttributeMethods
- include ActiveRecord::Dirty
end
require 'active_record/connection_adapters/abstract_adapter'
diff --git a/activerecord/lib/active_record/timestamp.rb b/activerecord/lib/active_record/timestamp.rb
index dc95d2aabb..a9e0efa6fe 100644
--- a/activerecord/lib/active_record/timestamp.rb
+++ b/activerecord/lib/active_record/timestamp.rb
@@ -30,7 +30,7 @@ module ActiveRecord
end
def update_with_timestamps(*args) #:nodoc:
- if record_timestamps
+ if record_timestamps && (!partial_updates? || changed?)
t = self.class.default_timezone == :utc ? Time.now.utc : Time.now
write_attribute('updated_at', t) if respond_to?(:updated_at)
write_attribute('updated_on', t) if respond_to?(:updated_on)