diff options
author | mame <mame@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-05-09 18:41:51 +0000 |
---|---|---|
committer | mame <mame@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-05-09 18:41:51 +0000 |
commit | b8571b4285fc222f51d2edaaa6dedde8654e0faf (patch) | |
tree | 8fa053f13f37eb57fe0227355538b0fc2c5135fc | |
parent | d49052b5970147a90b653f76ba18bd9af7a971ed (diff) |
* vm_eval.c (eval_string_with_cref): propagative filename and line_no
of binding. [ruby-dev:38767] [ruby-core:28307]
* vm_core.h (rb_binding_t), proc.c: add filename and line_no fields to
preserve them.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@27716 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 8 | ||||
-rw-r--r-- | bootstraptest/test_eval.rb | 2 | ||||
-rw-r--r-- | proc.c | 7 | ||||
-rw-r--r-- | vm_core.h | 2 | ||||
-rw-r--r-- | vm_eval.c | 4 |
5 files changed, 22 insertions, 1 deletions
@@ -1,3 +1,11 @@ +Mon May 10 03:36:56 2010 Yusuke Endoh <[email protected]> + + * vm_eval.c (eval_string_with_cref): propagative filename and line_no + of binding. [ruby-dev:38767] [ruby-core:28307] + + * vm_core.h (rb_binding_t), proc.c: add filename and line_no fields to + preserve them. + Mon May 10 02:58:33 2010 Yusuke Endoh <[email protected]> * compile.c (iseq_compile_each), vm_insnhelper.c (vm_invoke_block, diff --git a/bootstraptest/test_eval.rb b/bootstraptest/test_eval.rb index c5ab95302b..9ae50a6d30 100644 --- a/bootstraptest/test_eval.rb +++ b/bootstraptest/test_eval.rb @@ -287,7 +287,7 @@ assert_normal_exit %q{ eval("", method(:proc).call {}.binding) } -assert_equal "(eval):1:in `block in <main>': ", %q{ +assert_equal "", %q{ b = binding 10.times{ eval('', b) @@ -255,6 +255,7 @@ binding_mark(void *ptr) if (ptr) { bind = ptr; RUBY_MARK_UNLESS_NULL(bind->env); + RUBY_MARK_UNLESS_NULL(bind->filename); } RUBY_MARK_LEAVE("binding"); } @@ -290,6 +291,8 @@ binding_dup(VALUE self) GetBindingPtr(self, src); GetBindingPtr(bindval, dst); dst->env = src->env; + dst->filename = src->filename; + dst->line_no = src->line_no; return bindval; } @@ -316,6 +319,8 @@ rb_binding_new(void) GetBindingPtr(bindval, bind); bind->env = rb_vm_make_env_object(th, cfp); + bind->filename = cfp->iseq->filename; + bind->line_no = rb_vm_get_sourceline(cfp); return bindval; } @@ -1892,6 +1897,8 @@ proc_binding(VALUE self) bindval = binding_alloc(rb_cBinding); GetBindingPtr(bindval, bind); bind->env = proc->envval; + bind->filename = proc->block.iseq->filename; + bind->line_no = rb_iseq_first_lineno(proc->block.iseq); return bindval; } @@ -524,6 +524,8 @@ typedef struct { typedef struct { VALUE env; + VALUE filename; + unsigned short line_no; } rb_binding_t; /* used by compile time and send insn */ @@ -963,6 +963,10 @@ eval_string_with_cref(VALUE self, VALUE src, VALUE scope, NODE *cref, const char if (rb_obj_is_kind_of(scope, rb_cBinding)) { GetBindingPtr(scope, bind); envval = bind->env; + if (strcmp(file, "(eval)") == 0) { + file = RSTRING_PTR(bind->filename); + line = bind->line_no; + } } else { rb_raise(rb_eTypeError, |