diff options
author | Sean Griffin <sean@thoughtbot.com> | 2015-01-18 13:43:31 -0700 |
---|---|---|
committer | Sean Griffin <sean@thoughtbot.com> | 2015-01-18 13:43:31 -0700 |
commit | ea721d7027c16f64c47395546c67858060a273e3 (patch) | |
tree | e3eb8855e41610c491fbfd9757ae2ff7d49d45cf /activerecord/lib/active_record | |
parent | c542677310b7dbb205cf3bc24f74099ae929ca20 (diff) | |
download | rails-ea721d7027c16f64c47395546c67858060a273e3.tar.gz rails-ea721d7027c16f64c47395546c67858060a273e3.tar.bz2 rails-ea721d7027c16f64c47395546c67858060a273e3.zip |
Don't calculate in-place changes on attribute assignment
When an attribute is assigned, we determine if it was already marked as
changed so we can determine if we need to clear the changes, or mark it
as changed. Since this only affects the `attributes_changed_by_setter`
hash, in-place changes are irrelevant to this process. Since calculating
in-place changes can be expensive, we can just skip it here.
I also added a test for the only edge case I could think of that would
be affected by this change.
Diffstat (limited to 'activerecord/lib/active_record')
-rw-r--r-- | activerecord/lib/active_record/attribute_methods/dirty.rb | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/activerecord/lib/active_record/attribute_methods/dirty.rb b/activerecord/lib/active_record/attribute_methods/dirty.rb index ce7f575150..bce9c5e1e3 100644 --- a/activerecord/lib/active_record/attribute_methods/dirty.rb +++ b/activerecord/lib/active_record/attribute_methods/dirty.rb @@ -108,7 +108,7 @@ module ActiveRecord end def save_changed_attribute(attr, old_value) - if attribute_changed?(attr) + if attribute_changed_by_setter?(attr) clear_attribute_changes(attr) unless _field_changed?(attr, old_value) else set_attribute_was(attr, old_value) if _field_changed?(attr, old_value) |