diff options
author | Jeremy Evans <[email protected]> | 2019-07-22 19:56:02 -0700 |
---|---|---|
committer | Jeremy Evans <[email protected]> | 2019-12-05 03:04:38 +0200 |
commit | e4db0443bcfc94f9183e8ea72fb4ab560aa005bf (patch) | |
tree | a031ad5ea70ba3e8f7af65d929b8d4d1b985652e /vm_eval.c | |
parent | 18d3b5a93a2d52412f8f563d58db682b41d5c98c (diff) |
Make rb_eval_string_wrap specify a cref so constant setting works correctly
Fixes [Bug #10466]
Notes
Notes:
Merged: https://github.com/ruby/ruby/pull/2722
Diffstat (limited to 'vm_eval.c')
-rw-r--r-- | vm_eval.c | 22 |
1 files changed, 21 insertions, 1 deletions
@@ -1740,6 +1740,21 @@ rb_eval_string_protect(const char *str, int *pstate) return rb_protect(eval_string_protect, (VALUE)str, pstate); } +struct eval_string_wrap_arg { + VALUE top_self; + VALUE klass; + const char *str; +}; + +static VALUE +eval_string_wrap_protect(VALUE data) +{ + const struct eval_string_wrap_arg *const arg = (struct eval_string_wrap_arg*)data; + rb_cref_t *cref = rb_vm_cref_new_toplevel(); + cref->klass = arg->klass; + return eval_string_with_cref(arg->top_self, rb_str_new_cstr(arg->str), cref, rb_str_new_cstr("eval"), 1); +} + /** * Evaluates the given string under a module binding in an isolated binding. * This is same as the binding for loaded libraries on "load('foo', true)". @@ -1759,12 +1774,17 @@ rb_eval_string_wrap(const char *str, int *pstate) VALUE self = th->top_self; VALUE wrapper = th->top_wrapper; VALUE val; + struct eval_string_wrap_arg data; th->top_wrapper = rb_module_new(); th->top_self = rb_obj_clone(rb_vm_top_self()); rb_extend_object(th->top_self, th->top_wrapper); - val = rb_eval_string_protect(str, &state); + data.top_self = th->top_self; + data.klass = th->top_wrapper; + data.str = str; + + val = rb_protect(eval_string_wrap_protect, (VALUE)&data, &state); th->top_self = self; th->top_wrapper = wrapper; |