* sprintf.c (rb_str_format): fix for octal with precision.

[ruby-dev:33411]


git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@15278 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
nobu 2008-01-27 13:33:41 +00:00
parent ce26086b01
commit 7889fdd1e6
2 changed files with 22 additions and 8 deletions

View File

@ -1,3 +1,8 @@
Sun Jan 27 22:33:39 2008 Nobuyoshi Nakada <nobu@ruby-lang.org>
* sprintf.c (rb_str_format): fix for octal with precision.
[ruby-dev:33411]
Sun Jan 27 22:31:45 2008 Nobuyoshi Nakada <nobu@ruby-lang.org> Sun Jan 27 22:31:45 2008 Nobuyoshi Nakada <nobu@ruby-lang.org>
* misc/ruby-mode.el (ruby-mode-set-encoding): automatically insert * misc/ruby-mode.el (ruby-mode-set-encoding): automatically insert

View File

@ -535,9 +535,6 @@ rb_str_format(int argc, const VALUE *argv, VALUE fmt)
case 'B': case 'B':
prefix = "0B"; break; prefix = "0B"; break;
} }
if (prefix) {
width -= strlen(prefix);
}
} }
bin_retry: bin_retry:
@ -687,15 +684,27 @@ rb_str_format(int argc, const VALUE *argv, VALUE fmt)
pp++; pp++;
} }
} }
if (prefix && !prefix[1]) {
if (dots) {
prefix = 0;
}
else if (len == 1 && *s == '0') {
if (flags & FPREC) len = 0;
prefix = 0;
}
else if ((flags & FPREC) && (prec > len)) {
prefix = 0;
}
}
if (prefix) {
width -= strlen(prefix);
}
if ((flags&(FZERO|FPREC)) == FZERO) { if ((flags&(FZERO|FPREC)) == FZERO) {
prec = width; prec = width;
width = 0; width = 0;
} }
else { else {
if (prec < len) { if (prec < len) prec = len;
if ((flags & FPREC) && len == 1 && *s == '0') len = 0;
else prec = len;
}
width -= prec; width -= prec;
} }
if (!(flags&FMINUS)) { if (!(flags&FMINUS)) {
@ -705,7 +714,7 @@ rb_str_format(int argc, const VALUE *argv, VALUE fmt)
} }
} }
if (sc) PUSH(&sc, 1); if (sc) PUSH(&sc, 1);
if (prefix && (prefix[1] || !(dots || (len && s[0] == '0')))) { if (prefix) {
int plen = strlen(prefix); int plen = strlen(prefix);
PUSH(prefix, plen); PUSH(prefix, plen);
} }