diff options
author | usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2017-06-30 12:24:21 +0000 |
---|---|---|
committer | usa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2017-06-30 12:24:21 +0000 |
commit | 896d9fb9957f3c2d0a739e156f0775faa326d13c (patch) | |
tree | 7c26aa04264eee89e98b850c14d2d74d9e9af946 | |
parent | 75b1146985c30a4981c55e2d3e5458c686c63fe6 (diff) |
merge revision(s) 58210: [Backport #8916]
vsnprintf.c: prefix with precision
* vsnprintf.c (BSD_vfprintf): sign and hex-prefix should not be
counted in precision. [ruby-dev:47714] [Bug #8916]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_3@59233 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | strftime.c | 2 | ||||
-rw-r--r-- | version.h | 2 | ||||
-rw-r--r-- | vsnprintf.c | 10 |
4 files changed, 10 insertions, 9 deletions
@@ -1,3 +1,8 @@ +Fri Jun 30 21:23:20 2017 Nobuyoshi Nakada <nobu@ruby-lang.org> + + * vsnprintf.c (BSD_vfprintf): sign and hex-prefix should not be counted + in precision. [Bug #8916] + Fri Jun 30 21:20:14 2017 Koichi Sasada <ko1@atdot.net> * thread.c (ruby_thread_stack_overflow): disable VM events when stack diff --git a/strftime.c b/strftime.c index 83550e9a7f..e8099a3f12 100644 --- a/strftime.c +++ b/strftime.c @@ -497,7 +497,7 @@ rb_strftime_with_timespec(char *s, size_t maxsize, const char *format, rb_encodi goto unknown; } i = snprintf(s, endp - s, (padding == ' ' ? "%+*ld" : "%+.*ld"), - precision + 1, sign * (off / 3600)); + precision + (padding == ' '), sign * (off / 3600)); if (i < 0) goto err; if (sign < 0 && off < 3600) { *(padding == ' ' ? s + i - 2 : s) = '-'; @@ -1,6 +1,6 @@ #define RUBY_VERSION "2.3.5" #define RUBY_RELEASE_DATE "2017-06-30" -#define RUBY_PATCHLEVEL 329 +#define RUBY_PATCHLEVEL 330 #define RUBY_RELEASE_YEAR 2017 #define RUBY_RELEASE_MONTH 6 diff --git a/vsnprintf.c b/vsnprintf.c index 075bb4b2fe..0af1f5a573 100644 --- a/vsnprintf.c +++ b/vsnprintf.c @@ -1117,11 +1117,11 @@ number: if ((dprec = prec) >= 0) */ fieldsz = size; long_len: + realsz = dprec > fieldsz ? dprec : fieldsz; if (sign) - fieldsz++; + realsz++; if (flags & HEXPREFIX) - fieldsz += 2; - realsz = dprec > fieldsz ? dprec : fieldsz; + realsz += 2; /* right-adjusting blank padding */ if ((flags & (LADJUST|ZEROPAD)) == 0) @@ -1143,10 +1143,6 @@ long_len: /* leading zeroes from decimal precision */ PAD_L(dprec - fieldsz, zeroes); - if (sign) - fieldsz--; - if (flags & HEXPREFIX) - fieldsz -= 2; /* the string or number proper */ #ifdef FLOATING_POINT |