From a6aa6b67eb4620cac1378eb486ea58b8668a708f Mon Sep 17 00:00:00 2001 From: yugui Date: Sun, 30 Nov 2008 09:23:45 +0000 Subject: [PATCH] merges r20357 from trunk into ruby_1_9_1. * strftime.c (STRFTIME): should add padding for %[xXrR] etc. [ruby-dev:37185] fix: #792 git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_9_1@20415 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 +++++ strftime.c | 7 ++++++- 2 files changed, 11 insertions(+), 1 deletion(-) diff --git a/ChangeLog b/ChangeLog index dccb9cb4f7..c7fc21e92b 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Wed Nov 26 00:26:30 2008 Yukihiro Matsumoto + + * strftime.c (STRFTIME): should add padding for %[xXrR] etc. + [ruby-dev:37185] fix: #792 + Tue Nov 25 16:26:12 2008 Yukihiro Matsumoto * array.c (rb_ary_times): taint (and untrust) status should be diff --git a/strftime.c b/strftime.c index 7913c792a5..e2c8d5fabd 100644 --- a/strftime.c +++ b/strftime.c @@ -295,7 +295,12 @@ rb_strftime(char *s, size_t maxsize, const char *format, const struct tm *timept do { \ i = strftime(s, endp - s, fmt, tm); \ if (!i) return 0; \ - s += i; \ + if (precision > i) {\ + memmove(s + precision - i, s, i);\ + memset(s, padding ? padding : ' ', precision - i); \ + s += precision; \ + }\ + else s += i; \ } while (0) if (*format != '%') {