Skip to content
Permalink
Browse files
Fix out-of-bound access
Get rid of out-of-bound access when single % at the end.
  • Loading branch information
nobu committed Mar 13, 2017
1 parent 191ee25 commit d8c4fe7bcb07b4268184b526652311f28f0ce3a5
Showing 2 changed files with 12 additions and 0 deletions.
@@ -567,6 +567,7 @@ mrb_str_format(mrb_state *mrb, int argc, const mrb_value *argv, mrb_value fmt)
mrb_sym id = 0;

for (t = p; t < end && *t != '%'; t++) ;
if (t + 1 == end) ++t;
PUSH(p, t - p);
if (t >= end)
goto sprint_exit; /* end of fmt string */
@@ -30,3 +30,14 @@ class Fixnum
end
end
end

assert("String#% invalid format") do
assert_raise ArgumentError do
"%?" % ""
end
end

assert("String#% invalid format shared substring") do
fmt = ("x"*30+"%!")[0...-1]
assert_equal fmt, sprintf(fmt, "")
end

0 comments on commit d8c4fe7

Please sign in to comment.