[#57574] [ruby-trunk - Feature #8976][Open] file-scope freeze_string directive — "akr (Akira Tanaka)" <akr@...>

70 messages 2013/10/02

[#57579] [ruby-trunk - Feature #8977][Open] String#frozen that takes advantage of the deduping — "sam.saffron (Sam Saffron)" <sam.saffron@...>

25 messages 2013/10/02

[#57679] [ruby-trunk - Feature #8987][Open] map/collect extension which handles arguments — "sowieso (So Wieso)" <sowieso@...>

16 messages 2013/10/05

[#57705] [ruby-trunk - Feature #8992][Open] Use String#freeze and compiler tricks to replace "str"f suffix — "headius (Charles Nutter)" <headius@...>

43 messages 2013/10/07

[#57727] [ruby-trunk - Feature #8998][Open] string keys for hash literals should use fstrings — "normalperson (Eric Wong)" <normalperson@...>

17 messages 2013/10/08

[#57771] [ruby-trunk - Bug #9008][Open] TestProcess#test_clock_getres_constants and TestProcess#test_clock_gettime_constants fails on ARM — "vo.x (Vit Ondruch)" <v.ondruch@...>

15 messages 2013/10/09

[#57888] [ruby-trunk - Feature #9025][Open] Clarify the error message when calling a method with the wrong number of arguments — Nerian (Gonzalo Rodríguez) <siotopo@...>

11 messages 2013/10/15

[#57993] [ruby-trunk - Feature #9047][Open] Alternate hash key syntax for symbols — "jamonholmgren (Jamon Holmgren)" <jamon@...>

13 messages 2013/10/23

[#58007] [ruby-trunk - Feature #9049][Open] Shorthands (a:b, *) for inclusive indexing — "mohawkjohn (John Woods)" <john.o.woods@...>

25 messages 2013/10/24

[#58033] [ruby-trunk - Bug #9053][Open] SSL Issue with Ruby 2.0.0 — "tisba (Sebastian Cohnen)" <ruby-lang@...>

16 messages 2013/10/25

[#58080] [ruby-trunk - Feature #9064][Open] Add support for packages, like in Java — "rosenfeld (Rodrigo Rosenfeld Rosas)" <rr.rosas@...>

23 messages 2013/10/30

[ruby-core:57715] Re: [PATCH 1/2] time: fix strptime '%s'

From: Felipe Contreras <felipe.contreras@...>
Date: 2013-10-07 22:08:19 UTC
List: ruby-core #57715
On Mon, Oct 7, 2013 at 4:19 PM, Tanaka Akira <akr@fsij.org> wrote:
> 2013/10/8 Felipe Contreras <felipe.contreras@gmail.com>:
>
>> It doesn't really say '%s' is UTC, but that it's the seconds since the
>> Epoch (which is UTC).
>
> The Epoch is usually described in UTC but it doesn't mean it is UTC.
>
> The Epoch can be described as 1970-01-001 00:00:00 UTC,
> 1970-01-01 09:00:00 +0900 and others.
>
> %s format itself doesn't contain the information for offset from UTC.
>
> So I think it is not good idea to change the behavior
> (and possibly breaks compatibility) for Time.strptime('0', '%s') returns
> UTC Time object instead of local time Time object.

I don't feel strongly either way.

How about this?

--- a/lib/time.rb
+++ b/lib/time.rb
@@ -393,7 +393,7 @@ class Time
       d = Date._strptime(date, format)
       raise ArgumentError, "invalid strptime format - `#{format}'" unless d
       if seconds = d[:seconds]
-        Time.at(seconds)
+        Time.at(seconds).localtime(d[:offset])
       else
         year = d[:year]
         year = yield(year) if year && block_given?

'%s' remains the same, but '%s %z' is fixed:

Time.strptime('0', '%s')
=> 1969-12-31 18:00:00 -0600

Time.strptime('0 +0100', '%s %z')
=> 1970-01-01 01:00:00 +0100

Time.strptime('0 +0100', '%s %z').strftime('%s %z')
=> "0 +0100"

-- 
Felipe Contreras

In This Thread

Prev Next