Commit 6088276c authored by Yukihiro "Matz" Matsumoto's avatar Yukihiro "Matz" Matsumoto Committed by GitHub

Merge pull request #3630 from nobu/bug/sprintf-sp3inf

Fix space flag with inf/nan
parents 72bdb6a9 cd4e9a05
...@@ -1040,6 +1040,7 @@ retry: ...@@ -1040,6 +1040,7 @@ retry:
if (!isfinite(fval)) { if (!isfinite(fval)) {
const char *expr; const char *expr;
const int elen = 3; const int elen = 3;
char sign = '\0';
if (isnan(fval)) { if (isnan(fval)) {
expr = "NaN"; expr = "NaN";
...@@ -1048,35 +1049,26 @@ retry: ...@@ -1048,35 +1049,26 @@ retry:
expr = "Inf"; expr = "Inf";
} }
need = elen; need = elen;
if ((!isnan(fval) && fval < 0.0) || (flags & FPLUS)) if (!isnan(fval) && fval < 0.0)
need++; sign = '-';
else if (flags & (FPLUS|FSPACE))
sign = (flags & FPLUS) ? '+' : ' ';
if (sign)
++need;
if ((flags & FWIDTH) && need < width) if ((flags & FWIDTH) && need < width)
need = width; need = width;
CHECK(need + 1); FILL(' ', need);
n = snprintf(&buf[blen], need + 1, "%*s", need, "");
if (n < 0) {
mrb_raise(mrb, E_RUNTIME_ERROR, "formatting error");
}
if (flags & FMINUS) { if (flags & FMINUS) {
if (!isnan(fval) && fval < 0.0) if (sign)
buf[blen++] = '-'; buf[blen - need--] = sign;
else if (flags & FPLUS) memcpy(&buf[blen - need], expr, elen);
buf[blen++] = '+';
else if (flags & FSPACE)
blen++;
memcpy(&buf[blen], expr, elen);
} }
else { else {
if (!isnan(fval) && fval < 0.0) if (sign)
buf[blen + need - elen - 1] = '-'; buf[blen - elen - 1] = sign;
else if (flags & FPLUS) memcpy(&buf[blen - elen], expr, elen);
buf[blen + need - elen - 1] = '+';
else if ((flags & FSPACE) && need > width)
blen++;
memcpy(&buf[blen + need - elen], expr, elen);
} }
blen += strlen(&buf[blen]);
break; break;
} }
......
...@@ -8,6 +8,62 @@ assert('String#%') do ...@@ -8,6 +8,62 @@ assert('String#%') do
assert_equal 15, ("%b" % (1<<14)).size assert_equal 15, ("%b" % (1<<14)).size
end end
assert('String#% with inf') do
inf = Float::INFINITY
assert_equal "Inf", "%f" % inf
assert_equal "Inf", "%2f" % inf
assert_equal "Inf", "%3f" % inf
assert_equal " Inf", "%4f" % inf
assert_equal " Inf", "%5f" % inf
assert_equal "+Inf", "%+f" % inf
assert_equal "+Inf", "%+2f" % inf
assert_equal "+Inf", "%+3f" % inf
assert_equal "+Inf", "%+4f" % inf
assert_equal " +Inf", "%+5f" % inf
assert_equal "Inf", "%-f" % inf
assert_equal "Inf", "%-2f" % inf
assert_equal "Inf", "%-3f" % inf
assert_equal "Inf ", "%-4f" % inf
assert_equal "Inf ", "%-5f" % inf
assert_equal " Inf", "% f" % inf
assert_equal " Inf", "% 2f" % inf
assert_equal " Inf", "% 3f" % inf
assert_equal " Inf", "% 4f" % inf
assert_equal " Inf", "% 5f" % inf
end
assert('String#% with nan') do
nan = Float::NAN
assert_equal "NaN", "%f" % nan
assert_equal "NaN", "%2f" % nan
assert_equal "NaN", "%3f" % nan
assert_equal " NaN", "%4f" % nan
assert_equal " NaN", "%5f" % nan
assert_equal "+NaN", "%+f" % nan
assert_equal "+NaN", "%+2f" % nan
assert_equal "+NaN", "%+3f" % nan
assert_equal "+NaN", "%+4f" % nan
assert_equal " +NaN", "%+5f" % nan
assert_equal "NaN", "%-f" % nan
assert_equal "NaN", "%-2f" % nan
assert_equal "NaN", "%-3f" % nan
assert_equal "NaN ", "%-4f" % nan
assert_equal "NaN ", "%-5f" % nan
assert_equal " NaN", "% f" % nan
assert_equal " NaN", "% 2f" % nan
assert_equal " NaN", "% 3f" % nan
assert_equal " NaN", "% 4f" % nan
assert_equal " NaN", "% 5f" % nan
end
assert("String#% with invalid chr") do assert("String#% with invalid chr") do
begin begin
class Fixnum class Fixnum
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment