aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/active_record/attribute_methods/time_zone_conversion.rb
diff options
context:
space:
mode:
authorJon Leighton <j@jonathanleighton.com>2011-12-01 17:55:27 +0000
committerJon Leighton <j@jonathanleighton.com>2011-12-01 23:41:51 +0000
commitf1a534af98950efd9969deea1540717c4516d673 (patch)
treeee42e61af1e39c9f9f9fab02cce06c83753965ff /activerecord/lib/active_record/attribute_methods/time_zone_conversion.rb
parent47b97a739d5588cfa439a4805fb1ddd3b7a7acbe (diff)
downloadrails-f1a534af98950efd9969deea1540717c4516d673.tar.gz
rails-f1a534af98950efd9969deea1540717c4516d673.tar.bz2
rails-f1a534af98950efd9969deea1540717c4516d673.zip
Remove the need for type_cast_attribute.
This is good because it reduces duplication.
Diffstat (limited to 'activerecord/lib/active_record/attribute_methods/time_zone_conversion.rb')
-rw-r--r--activerecord/lib/active_record/attribute_methods/time_zone_conversion.rb19
1 files changed, 16 insertions, 3 deletions
diff --git a/activerecord/lib/active_record/attribute_methods/time_zone_conversion.rb b/activerecord/lib/active_record/attribute_methods/time_zone_conversion.rb
index 7cde9dbffd..d7972917fe 100644
--- a/activerecord/lib/active_record/attribute_methods/time_zone_conversion.rb
+++ b/activerecord/lib/active_record/attribute_methods/time_zone_conversion.rb
@@ -19,12 +19,15 @@ module ActiveRecord
# Defined for all +datetime+ and +timestamp+ attributes when +time_zone_aware_attributes+ are enabled.
# This enhanced read method automatically converts the UTC time stored in the database to the time
# zone stored in Time.zone.
- def attribute_access_code(attr_name)
- if create_time_zone_conversion_attribute?(attr_name, columns_hash[attr_name])
+ def internal_attribute_access_code(attr_name)
+ column = columns_hash[attr_name]
+
+ if create_time_zone_conversion_attribute?(attr_name, column)
<<-CODE
cached = @attributes_cache['#{attr_name}']
return cached if cached
- time = _read_attribute('#{attr_name}')
+ v = @attributes['#{attr_name}']
+ time = #{column.type_cast_code('v')}
@attributes_cache['#{attr_name}'] = time.acts_like?(:time) ? time.in_time_zone : time
CODE
else
@@ -32,6 +35,16 @@ module ActiveRecord
end
end
+ def external_attribute_access_code(attr_name)
+ column = columns_hash[attr_name]
+
+ if create_time_zone_conversion_attribute?(attr_name, column)
+ "attributes_cache[attr_name] ||= (#{attribute_cast_code(attr_name)})"
+ else
+ super
+ end
+ end
+
def attribute_cast_code(attr_name)
if create_time_zone_conversion_attribute?(attr_name, columns_hash[attr_name])
"v.acts_like?(:time) ? v.in_time_zone : v"