aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib
diff options
context:
space:
mode:
authorAndrew White <andyw@pixeltrix.co.uk>2013-09-24 21:37:53 -0700
committerAndrew White <andyw@pixeltrix.co.uk>2013-09-24 21:37:53 -0700
commitf3982858359008ec8fe43b8fa2c75aad8788cd89 (patch)
tree03699ec7b03e291982530c43bd84aff93d315d35 /activerecord/lib
parent1acef69aa65e3bc502128dddbaa93e2de108f99b (diff)
parent8dd5a582f544ca86add20d46c2a62b965b28e08a (diff)
downloadrails-f3982858359008ec8fe43b8fa2c75aad8788cd89.tar.gz
rails-f3982858359008ec8fe43b8fa2c75aad8788cd89.tar.bz2
rails-f3982858359008ec8fe43b8fa2c75aad8788cd89.zip
Merge pull request #12290 from kennyj/fix_12278
Closes #12278. AR::ConnectionAdapters::Column.string_to_time method respects string with timezone.
Diffstat (limited to 'activerecord/lib')
-rw-r--r--activerecord/lib/active_record/connection_adapters/column.rb14
1 files changed, 11 insertions, 3 deletions
diff --git a/activerecord/lib/active_record/connection_adapters/column.rb b/activerecord/lib/active_record/connection_adapters/column.rb
index fb53090edc..2596c221bc 100644
--- a/activerecord/lib/active_record/connection_adapters/column.rb
+++ b/activerecord/lib/active_record/connection_adapters/column.rb
@@ -203,11 +203,19 @@ module ActiveRecord
end
end
- def new_time(year, mon, mday, hour, min, sec, microsec)
+ def new_time(year, mon, mday, hour, min, sec, microsec, offset = nil)
# Treat 0000-00-00 00:00:00 as nil.
return nil if year.nil? || (year == 0 && mon == 0 && mday == 0)
- Time.send(Base.default_timezone, year, mon, mday, hour, min, sec, microsec) rescue nil
+ if offset
+ time = Time.utc(year, mon, mday, hour, min, sec, microsec) rescue nil
+ return nil unless time
+
+ time -= offset
+ Base.default_timezone == :utc ? time : time.getlocal
+ else
+ Time.public_send(Base.default_timezone, year, mon, mday, hour, min, sec, microsec) rescue nil
+ end
end
def fast_string_to_date(string)
@@ -232,7 +240,7 @@ module ActiveRecord
time_hash = Date._parse(string)
time_hash[:sec_fraction] = microseconds(time_hash)
- new_time(*time_hash.values_at(:year, :mon, :mday, :hour, :min, :sec, :sec_fraction))
+ new_time(*time_hash.values_at(:year, :mon, :mday, :hour, :min, :sec, :sec_fraction, :offset))
end
end