diff options
author | Sean Griffin <sean@thoughtbot.com> | 2014-06-06 12:28:22 -0600 |
---|---|---|
committer | Sean Griffin <sean@thoughtbot.com> | 2014-06-06 13:53:13 -0600 |
commit | 332d6c9b6ffdc6e4ca7886593256b5f994679316 (patch) | |
tree | ac42d08a47d017a5f95297492864ff99c62dc50d | |
parent | 6680ee9427ae2639e404cd3b9538f54e136057c6 (diff) | |
download | rails-332d6c9b6ffdc6e4ca7886593256b5f994679316.tar.gz rails-332d6c9b6ffdc6e4ca7886593256b5f994679316.tar.bz2 rails-332d6c9b6ffdc6e4ca7886593256b5f994679316.zip |
Don't mess with `_before_type_cast` for numeric types
-rw-r--r-- | activerecord/lib/active_record/connection_adapters/postgresql/oid/float.rb | 3 | ||||
-rw-r--r-- | activerecord/lib/active_record/type/numeric.rb | 15 |
2 files changed, 9 insertions, 9 deletions
diff --git a/activerecord/lib/active_record/connection_adapters/postgresql/oid/float.rb b/activerecord/lib/active_record/connection_adapters/postgresql/oid/float.rb index 9753d71461..77dd97e140 100644 --- a/activerecord/lib/active_record/connection_adapters/postgresql/oid/float.rb +++ b/activerecord/lib/active_record/connection_adapters/postgresql/oid/float.rb @@ -5,9 +5,8 @@ module ActiveRecord class Float < Type::Float include Infinity - def type_cast(value) + def cast_value(value) case value - when nil then nil when 'Infinity' then ::Float::INFINITY when '-Infinity' then -::Float::INFINITY when 'NaN' then ::Float::NAN diff --git a/activerecord/lib/active_record/type/numeric.rb b/activerecord/lib/active_record/type/numeric.rb index 9cc6411e77..d5cb13233c 100644 --- a/activerecord/lib/active_record/type/numeric.rb +++ b/activerecord/lib/active_record/type/numeric.rb @@ -5,13 +5,14 @@ module ActiveRecord true end - def type_cast_for_write(value) - case value - when true then 1 - when false then 0 - when ::String then value.presence - else super - end + def type_cast(value) + value = case value + when true then 1 + when false then 0 + when ::String then value.presence + else value + end + super(value) end def changed?(old_value, new_value) # :nodoc: |