* 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:
parent
ce26086b01
commit
7889fdd1e6
@ -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
|
||||||
|
25
sprintf.c
25
sprintf.c
@ -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);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user