summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2017-06-30 12:24:21 +0000
committerusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2017-06-30 12:24:21 +0000
commit896d9fb9957f3c2d0a739e156f0775faa326d13c (patch)
tree7c26aa04264eee89e98b850c14d2d74d9e9af946
parent75b1146985c30a4981c55e2d3e5458c686c63fe6 (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--ChangeLog5
-rw-r--r--strftime.c2
-rw-r--r--version.h2
-rw-r--r--vsnprintf.c10
4 files changed, 10 insertions, 9 deletions
diff --git a/ChangeLog b/ChangeLog
index c342abc1e9..237567d8b9 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -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) = '-';
diff --git a/version.h b/version.h
index f512c73c56..0005fdf3bc 100644
--- a/version.h
+++ b/version.h
@@ -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