зеркало из https://github.com/github/ruby.git
strftime.c: triple colons modifier
partially borrowed from ext/date. * strftime.c (rb_strftime_with_timespec): support GNU extension triple colons modifier. [EXPERIMENTAL] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@35836 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
Родитель
241902e709
Коммит
39a3d1793b
|
@ -1,4 +1,7 @@
|
|||
Tue May 29 17:28:15 2012 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
Tue May 29 17:28:20 2012 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
|
||||
* strftime.c (rb_strftime_with_timespec): support GNU extension triple
|
||||
colons modifier. [EXPERIMENTAL]
|
||||
|
||||
* strftime.c (rb_strftime_with_timespec): check conversion with locale
|
||||
modifier.
|
||||
|
|
43
strftime.c
43
strftime.c
|
@ -460,6 +460,18 @@ rb_strftime_with_timespec(char *s, size_t maxsize, const char *format, rb_encodi
|
|||
|
||||
#ifdef MAILHEADER_EXT
|
||||
case 'z': /* time zone offset east of GMT e.g. -0600 */
|
||||
if (gmt) {
|
||||
off = 0;
|
||||
}
|
||||
else {
|
||||
off = NUM2LONG(rb_funcall(vtm->utc_offset, rb_intern("round"), 0));
|
||||
}
|
||||
if (off < 0) {
|
||||
off = -off;
|
||||
sign = -1;
|
||||
} else {
|
||||
sign = +1;
|
||||
}
|
||||
switch (colons) {
|
||||
case 0: /* %z -> +hhmm */
|
||||
precision = precision <= 5 ? 2 : precision-3;
|
||||
|
@ -476,22 +488,25 @@ rb_strftime_with_timespec(char *s, size_t maxsize, const char *format, rb_encodi
|
|||
NEEDS(precision + 7);
|
||||
break;
|
||||
|
||||
case 3: /* %:::z -> +hh[:mm[:ss]] */
|
||||
if (off % 3600 == 0) {
|
||||
precision = precision <= 3 ? 2 : precision-1;
|
||||
NEEDS(precision + 3);
|
||||
}
|
||||
else if (off % 60 == 0) {
|
||||
precision = precision <= 6 ? 2 : precision-4;
|
||||
NEEDS(precision + 4);
|
||||
}
|
||||
else {
|
||||
precision = precision <= 9 ? 2 : precision-7;
|
||||
NEEDS(precision + 9);
|
||||
}
|
||||
break;
|
||||
|
||||
default:
|
||||
format--;
|
||||
goto unknown;
|
||||
}
|
||||
if (gmt) {
|
||||
off = 0;
|
||||
}
|
||||
else {
|
||||
off = NUM2LONG(rb_funcall(vtm->utc_offset, rb_intern("round"), 0));
|
||||
}
|
||||
if (off < 0) {
|
||||
off = -off;
|
||||
sign = -1;
|
||||
} else {
|
||||
sign = +1;
|
||||
}
|
||||
i = snprintf(s, endp - s, (padding == ' ' ? "%+*ld" : "%+.*ld"),
|
||||
precision + 1, sign * (off / 3600));
|
||||
if (i < 0) goto err;
|
||||
|
@ -500,12 +515,16 @@ rb_strftime_with_timespec(char *s, size_t maxsize, const char *format, rb_encodi
|
|||
}
|
||||
s += i;
|
||||
off = off % 3600;
|
||||
if (colons == 3 && off == 0)
|
||||
continue;
|
||||
if (1 <= colons)
|
||||
*s++ = ':';
|
||||
i = snprintf(s, endp - s, "%02d", (int)(off / 60));
|
||||
if (i < 0) goto err;
|
||||
s += i;
|
||||
off = off % 60;
|
||||
if (colons == 3 && off == 0)
|
||||
continue;
|
||||
if (2 <= colons) {
|
||||
*s++ = ':';
|
||||
i = snprintf(s, endp - s, "%02d", (int)off);
|
||||
|
|
|
@ -695,6 +695,20 @@ class TestTime < Test::Unit::TestCase
|
|||
assert_raise(Errno::ERANGE, bug4457) {Time.now.strftime('%8192z')}
|
||||
end
|
||||
|
||||
def test_strfimte_zoneoffset
|
||||
t = T2000.getlocal("+09:00:00")
|
||||
assert_equal("+0900", t.strftime("%z"))
|
||||
assert_equal("+09:00", t.strftime("%:z"))
|
||||
assert_equal("+09:00:01", t.strftime("%::z"))
|
||||
assert_equal("+09", t.strftime("%:::z"))
|
||||
|
||||
t = T2000.getlocal("+09:00:01")
|
||||
assert_equal("+0900", t.strftime("%z"))
|
||||
assert_equal("+09:00", t.strftime("%:z"))
|
||||
assert_equal("+09:00:01", t.strftime("%::z"))
|
||||
assert_equal("+09:00:01", t.strftime("%:::z"))
|
||||
end
|
||||
|
||||
def test_strftime_padding
|
||||
bug4458 = '[ruby-dev:43287]'
|
||||
t = T2000.getlocal("+09:00")
|
||||
|
@ -706,6 +720,7 @@ class TestTime < Test::Unit::TestCase
|
|||
assert_equal("+000009:00", t.strftime("%10:z"), bug4458)
|
||||
assert_equal(" +9:00:00", t.strftime("%_10::z"), bug4458)
|
||||
assert_equal("+009:00:00", t.strftime("%10::z"), bug4458)
|
||||
assert_equal("+000000009", t.strftime("%10:::z"))
|
||||
t = T2000.getlocal("-05:00")
|
||||
assert_equal("-0500", t.strftime("%z"))
|
||||
assert_equal("-05:00", t.strftime("%:z"))
|
||||
|
@ -715,6 +730,7 @@ class TestTime < Test::Unit::TestCase
|
|||
assert_equal("-000005:00", t.strftime("%10:z"), bug4458)
|
||||
assert_equal(" -5:00:00", t.strftime("%_10::z"), bug4458)
|
||||
assert_equal("-005:00:00", t.strftime("%10::z"), bug4458)
|
||||
assert_equal("-000000005", t.strftime("%10:::z"))
|
||||
|
||||
bug6323 = '[ruby-core:44447]'
|
||||
t = T2000.getlocal("+00:36")
|
||||
|
@ -724,6 +740,7 @@ class TestTime < Test::Unit::TestCase
|
|||
assert_equal("+000000:36", t.strftime("%10:z"), bug6323)
|
||||
assert_equal(" +0:36:00", t.strftime("%_10::z"), bug6323)
|
||||
assert_equal("+000:36:00", t.strftime("%10::z"), bug6323)
|
||||
assert_equal("+000000:36", t.strftime("%10:::z"))
|
||||
t = T2000.getlocal("-00:55")
|
||||
assert_equal(" -055", t.strftime("%_10z"), bug6323)
|
||||
assert_equal("-000000055", t.strftime("%10z"), bug6323)
|
||||
|
@ -731,6 +748,7 @@ class TestTime < Test::Unit::TestCase
|
|||
assert_equal("-000000:55", t.strftime("%10:z"), bug6323)
|
||||
assert_equal(" -0:55:00", t.strftime("%_10::z"), bug6323)
|
||||
assert_equal("-000:55:00", t.strftime("%10::z"), bug6323)
|
||||
assert_equal("-000000:55", t.strftime("%10:::z"))
|
||||
end
|
||||
|
||||
def test_strftime_invalid_modifier
|
||||
|
|
Загрузка…
Ссылка в новой задаче