Commit abca63c7 authored by Asmod4n's avatar Asmod4n Committed by GitHub

Save gc_arena after buffer got allocated

Latest fix was freeing the buffer while it was still in use.
Fixes #3712
parent 0de7eec6
...@@ -601,12 +601,12 @@ mrb_str_upto(mrb_state *mrb, mrb_value beg) ...@@ -601,12 +601,12 @@ mrb_str_upto(mrb_state *mrb, mrb_value beg)
if (ISDIGIT(RSTRING_PTR(beg)[0]) && ISDIGIT(RSTRING_PTR(end)[0]) && if (ISDIGIT(RSTRING_PTR(beg)[0]) && ISDIGIT(RSTRING_PTR(end)[0]) &&
all_digits_p(RSTRING_PTR(beg), RSTRING_LEN(beg)) && all_digits_p(RSTRING_PTR(beg), RSTRING_LEN(beg)) &&
all_digits_p(RSTRING_PTR(end), RSTRING_LEN(end))) { all_digits_p(RSTRING_PTR(end), RSTRING_LEN(end))) {
int ai = mrb_gc_arena_save(mrb);
mrb_int min_width = RSTRING_LEN(beg); mrb_int min_width = RSTRING_LEN(beg);
mrb_int max_width = RSTRING_LEN(end); mrb_int max_width = RSTRING_LEN(end);
mrb_int bi = mrb_int(mrb, mrb_str_to_inum(mrb, beg, 10, FALSE)); mrb_int bi = mrb_int(mrb, mrb_str_to_inum(mrb, beg, 10, FALSE));
mrb_int ei = mrb_int(mrb, mrb_str_to_inum(mrb, end, 10, FALSE)); mrb_int ei = mrb_int(mrb, mrb_str_to_inum(mrb, end, 10, FALSE));
mrb_value str = mrb_str_new(mrb, NULL, max_width); mrb_value str = mrb_str_new(mrb, NULL, max_width);
int ai = mrb_gc_arena_save(mrb);
char *buf = RSTRING_PTR(str); char *buf = RSTRING_PTR(str);
while (bi <= ei) { while (bi <= ei) {
......
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