aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGeoff Buesing <gbuesing@gmail.com>2008-01-26 00:34:44 +0000
committerGeoff Buesing <gbuesing@gmail.com>2008-01-26 00:34:44 +0000
commit8ef3dfff7a48bd0609ba4067c54910880fc6ef88 (patch)
treec581f9412c531bce307c764ee6360a39648940b0
parentc95365a00eb086f61cb5e73e9e6d5dae54325b60 (diff)
downloadrails-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
-rw-r--r--activesupport/CHANGELOG2
-rw-r--r--activesupport/lib/active_support/time_with_zone.rb6
-rw-r--r--activesupport/test/core_ext/time_with_zone_test.rb1
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