summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2012-04-17 13:18:51 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2012-04-17 13:18:51 +0000
commit43dbbefbdf9cf46933bb4c24929de9e8b1a66429 (patch)
tree81e02f1467662dfdb867c84002b1770dbf6a0e8a
parent77321aeed941c7fd2e09c881e636562440217511 (diff)
* strftime.c (rb_strftime_with_timespec): fix padding of time zone
offset. [ruby-dev:43287][Bug #4458] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@35366 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--strftime.c10
-rw-r--r--test/ruby/test_time.rb16
3 files changed, 28 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog
index 73e09fc709..6e1bfc8369 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Tue Apr 17 22:18:48 2012 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * strftime.c (rb_strftime_with_timespec): fix padding of time zone
+ offset. [ruby-dev:43287][Bug #4458]
+
Tue Apr 17 13:11:14 2012 Nobuyoshi Nakada <nobu@ruby-lang.org>
* dln.c (rb_w32_check_imported): skip ordinal entries. based on a
diff --git a/strftime.c b/strftime.c
index b02c482d3b..3a50e55fbd 100644
--- a/strftime.c
+++ b/strftime.c
@@ -189,6 +189,9 @@ rb_strftime_with_timespec(char *s, size_t maxsize, const char *format, rb_encodi
char padding;
enum {LEFT, CHCASE, LOWER, UPPER, LOCALE_O, LOCALE_E};
#define BIT_OF(n) (1U<<(n))
+#ifdef MAILHEADER_EXT
+ int sign;
+#endif
/* various tables, useful in North America */
static const char days_l[][10] = {
@@ -485,11 +488,12 @@ rb_strftime_with_timespec(char *s, size_t maxsize, const char *format, rb_encodi
}
if (off < 0) {
off = -off;
- *s++ = '-';
+ sign = -1;
} else {
- *s++ = '+';
+ sign = +1;
}
- i = snprintf(s, endp - s, (padding == ' ' ? "%*ld" : "%.*ld"), precision, off / 3600);
+ i = snprintf(s, endp - s, (padding == ' ' ? "%+*ld" : "%+.*ld"),
+ precision + 1, sign * (off / 3600));
if (i < 0) goto err;
s += i;
off = off % 3600;
diff --git a/test/ruby/test_time.rb b/test/ruby/test_time.rb
index e62aaf80c8..573b563177 100644
--- a/test/ruby/test_time.rb
+++ b/test/ruby/test_time.rb
@@ -668,6 +668,22 @@ class TestTime < Test::Unit::TestCase
bug4457 = '[ruby-dev:43285]'
assert_raise(Errno::ERANGE, bug4457) {Time.now.strftime('%8192z')}
+
+ bug4458 = '[ruby-dev:43287]'
+ t = T2000.getlocal("+09:00")
+ assert_equal(" +900", t.strftime("%_10z"), bug4458)
+ assert_equal("+000000900", t.strftime("%10z"), bug4458)
+ assert_equal(" +9:00", t.strftime("%_:10z"), bug4458)
+ assert_equal("+000009:00", t.strftime("%:10z"), bug4458)
+ assert_equal(" +9:00:00", t.strftime("%_::10z"), bug4458)
+ assert_equal("+009:00:00", t.strftime("%::10z"), bug4458)
+ t = T2000.getlocal("-05:00")
+ assert_equal(" -500", t.strftime("%_10z"), bug4458)
+ assert_equal("-000000500", t.strftime("%10z"), bug4458)
+ assert_equal(" -5:00", t.strftime("%_:10z"), bug4458)
+ assert_equal("-000005:00", t.strftime("%:10z"), bug4458)
+ assert_equal(" -5:00:00", t.strftime("%_::10z"), bug4458)
+ assert_equal("-005:00:00", t.strftime("%::10z"), bug4458)
end
def test_delegate