diff options
author | Geoff Buesing <gbuesing@gmail.com> | 2008-01-26 00:34:44 +0000 |
---|---|---|
committer | Geoff Buesing <gbuesing@gmail.com> | 2008-01-26 00:34:44 +0000 |
commit | 8ef3dfff7a48bd0609ba4067c54910880fc6ef88 (patch) | |
tree | c581f9412c531bce307c764ee6360a39648940b0 /activesupport | |
parent | c95365a00eb086f61cb5e73e9e6d5dae54325b60 (diff) | |
download | rails-8ef3dfff7a48bd0609ba4067c54910880fc6ef88.tar.gz rails-8ef3dfff7a48bd0609ba4067c54910880fc6ef88.tar.bz2 rails-8ef3dfff7a48bd0609ba4067c54910880fc6ef88.zip |
TimeWithZone#- added, so that #- can handle a Time or TimeWithZone argument correctly
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@8732 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'activesupport')
-rw-r--r-- | activesupport/CHANGELOG | 2 | ||||
-rw-r--r-- | activesupport/lib/active_support/time_with_zone.rb | 6 | ||||
-rw-r--r-- | activesupport/test/core_ext/time_with_zone_test.rb | 1 |
3 files changed, 9 insertions, 0 deletions
diff --git a/activesupport/CHANGELOG b/activesupport/CHANGELOG index 007764adef..51e073b1bd 100644 --- a/activesupport/CHANGELOG +++ b/activesupport/CHANGELOG @@ -1,5 +1,7 @@ *SVN* +* TimeWithZone#- added, so that #- can handle a Time or TimeWithZone argument correctly [Geoff Buesing] + * with_timezone test helper renamed with_env_tz, to distinguish between setting ENV['TZ'] and setting Time.zone in tests [Geoff Buesing] * Time#- coerces TimeWithZone argument to a Time instance so that difference in seconds can be calculated. Closes #10914 [Geoff Buesing, yyyc514] diff --git a/activesupport/lib/active_support/time_with_zone.rb b/activesupport/lib/active_support/time_with_zone.rb index e65c77a8b6..c5810c2c19 100644 --- a/activesupport/lib/active_support/time_with_zone.rb +++ b/activesupport/lib/active_support/time_with_zone.rb @@ -106,6 +106,12 @@ module ActiveSupport def <=>(other) utc <=> other end + + # Need to override #- to intercept situation where a Time or Time With Zone object is passed in + # Otherwise, just pass on to method missing + def -(other) + other.acts_like?(:time) ? utc - other : method_missing(:-, other) + end # A TimeProxy acts like a Time, so just return self def to_time diff --git a/activesupport/test/core_ext/time_with_zone_test.rb b/activesupport/test/core_ext/time_with_zone_test.rb index 9276656db5..eae4d3094e 100644 --- a/activesupport/test/core_ext/time_with_zone_test.rb +++ b/activesupport/test/core_ext/time_with_zone_test.rb @@ -124,6 +124,7 @@ uses_tzinfo 'TimeWithZoneTest' do def test_minus_with_time assert_equal 86_400.0, ActiveSupport::TimeWithZone.new( Time.utc(2000, 1, 2), TimeZone['UTC'] ) - Time.utc(2000, 1, 1) + assert_equal 86_400.0, ActiveSupport::TimeWithZone.new( Time.utc(2000, 1, 2), TimeZone['Hawaii'] ) - Time.utc(2000, 1, 1) end def test_minus_with_time_with_zone |