aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--ChangeLog9
-rw-r--r--lib/rss/rss.rb2
-rw-r--r--lib/time.rb16
-rw-r--r--test/test_time.rb13
4 files changed, 35 insertions, 5 deletions
diff --git a/ChangeLog b/ChangeLog
index af14c8a5be..57bd133144 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,12 @@
+Sat May 3 23:52:20 2014 Tanaka Akira <akr@fsij.org>
+
+ * lib/time.rb (make_time): Produce fixed-offset time object if
+ appropriate.
+ (Time.strptime): Use d[:zone] instead of d[:offset].
+
+ * lib/rss/rss.rb (Time.w3cdtf): Produce fixed-offset time object if
+ appropriate.
+
Sat May 3 20:21:38 2014 Tanaka Akira <akr@fsij.org>
* lib/time.rb (Time.strptime): Use d[:offset] if d[:seconds] is not
diff --git a/lib/rss/rss.rb b/lib/rss/rss.rb
index a33d21c97e..fc4f9328ac 100644
--- a/lib/rss/rss.rb
+++ b/lib/rss/rss.rb
@@ -28,7 +28,7 @@ class Time
datetime = apply_offset(*(datetime + [off]))
datetime << usec
time = Time.utc(*datetime)
- time.localtime unless zone_utc?(zone)
+ time.localtime(off) unless zone_utc?(zone)
time
else
datetime << usec
diff --git a/lib/time.rb b/lib/time.rb
index 8ffd42dcd7..507bf28daf 100644
--- a/lib/time.rb
+++ b/lib/time.rb
@@ -258,7 +258,11 @@ class Time
year, mon, day, hour, min, sec =
apply_offset(year, mon, day, hour, min, sec, off)
t = self.utc(year, mon, day, hour, min, sec, usec)
- t.localtime if !zone_utc?(zone)
+ if zone_utc?(zone)
+ t.utc
+ else
+ t.localtime(off)
+ end
t
else
self.local(year, mon, day, hour, min, sec, usec)
@@ -394,14 +398,18 @@ class Time
raise ArgumentError, "invalid strptime format - `#{format}'" unless d
if seconds = d[:seconds]
t = Time.at(seconds)
+ if zone = d[:zone]
+ if zone_utc?(zone)
+ t.utc
+ elsif offset = zone_offset(zone)
+ t.localtime(offset)
+ end
+ end
else
year = d[:year]
year = yield(year) if year && block_given?
t = make_time(year, d[:mon], d[:mday], d[:hour], d[:min], d[:sec], d[:sec_fraction], d[:zone], now)
end
- if offset = d[:offset]
- t.localtime(offset)
- end
t
end
diff --git a/test/test_time.rb b/test/test_time.rb
index 1427089abb..fe8fb9288e 100644
--- a/test/test_time.rb
+++ b/test/test_time.rb
@@ -407,6 +407,10 @@ class TestTimeExtension < Test::Unit::TestCase # :nodoc:
t = Time.strptime('0 +0100', '%s %z')
assert_equal(0, t.to_r)
assert_equal(3600, t.utc_offset)
+ t = Time.strptime('0 UTC', '%s %z')
+ assert_equal(0, t.to_r)
+ assert_equal(0, t.utc_offset)
+ assert_equal(true, t.utc?)
end
def test_strptime_Ymd_z
@@ -418,6 +422,15 @@ class TestTimeExtension < Test::Unit::TestCase # :nodoc:
assert_equal(0, t.min)
assert_equal(0, t.sec)
assert_equal(-7200, t.utc_offset)
+ t = Time.strptime('20010203 UTC', '%Y%m%d %z')
+ assert_equal(2001, t.year)
+ assert_equal(2, t.mon)
+ assert_equal(3, t.day)
+ assert_equal(0, t.hour)
+ assert_equal(0, t.min)
+ assert_equal(0, t.sec)
+ assert_equal(0, t.utc_offset)
+ assert_equal(true, t.utc?)
end
def test_nsec