summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-02-13 06:25:59 +0000
committerko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2009-02-13 06:25:59 +0000
commit5ad885af7515ec3ed9470e8caee79f9ab3fc73b8 (patch)
tree2ed06dab1c9b981ac617b6bff3932f4107137891
parentad278cc0f126e987a458a2f7d6f72636b95d9e3a (diff)
downloadruby-5ad885af7515ec3ed9470e8caee79f9ab3fc73b8.tar.gz
ruby-5ad885af7515ec3ed9470e8caee79f9ab3fc73b8.tar.xz
ruby-5ad885af7515ec3ed9470e8caee79f9ab3fc73b8.zip
* vm_eval.c (eval_string_with_cref): use rb_vm_get_ruby_level_next_cfp()
instead of vm_get_ruby_level_caller_cfp(). checking a upper frame is not enough. [ruby-dev:37984] * proc.c, vm_core.h: declare rb_vm_get_ruby_level_next_cfp() on vm_core.h. git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@22275 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog9
-rw-r--r--proc.c2
-rw-r--r--vm_core.h1
-rw-r--r--vm_eval.c2
4 files changed, 11 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog
index e296dea3d..3c22cbebb 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,12 @@
+Fri Feb 13 15:11:11 2009 Koichi Sasada <ko1@atdot.net>
+
+ * vm_eval.c (eval_string_with_cref): use rb_vm_get_ruby_level_next_cfp()
+ instead of vm_get_ruby_level_caller_cfp(). checking a upper frame
+ is not enough. [ruby-dev:37984]
+
+ * proc.c, vm_core.h: declare rb_vm_get_ruby_level_next_cfp()
+ on vm_core.h.
+
Fri Feb 13 15:01:40 2009 Koichi Sasada <ko1@atdot.net>
* cont.c (rb_fiber_alive_p): fix to return true instead of 1.
diff --git a/proc.c b/proc.c
index dea1a0e10..276115881 100644
--- a/proc.c
+++ b/proc.c
@@ -274,8 +274,6 @@ binding_clone(VALUE self)
return bindval;
}
-rb_control_frame_t *rb_vm_get_ruby_level_next_cfp(rb_thread_t *th, rb_control_frame_t *cfp);
-
VALUE
rb_binding_new(void)
{
diff --git a/vm_core.h b/vm_core.h
index 4d6ddcc64..dd5f3400d 100644
--- a/vm_core.h
+++ b/vm_core.h
@@ -593,6 +593,7 @@ int ruby_thread_has_gvl_p(void);
VALUE rb_make_backtrace(void);
typedef int rb_backtrace_iter_func(void *, const char *, int, const char *);
VALUE rb_backtrace_each(rb_backtrace_iter_func *iter, void *arg);
+rb_control_frame_t *rb_vm_get_ruby_level_next_cfp(rb_thread_t *th, rb_control_frame_t *cfp);
NOINLINE(void rb_gc_save_machine_context(rb_thread_t *));
diff --git a/vm_eval.c b/vm_eval.c
index ed0e34a6c..b43e88d37 100644
--- a/vm_eval.c
+++ b/vm_eval.c
@@ -706,7 +706,7 @@ eval_string_with_cref(VALUE self, VALUE src, VALUE scope, NODE *cref, const char
th->base_block = &env->block;
}
else {
- rb_control_frame_t *cfp = vm_get_ruby_level_caller_cfp(th, th->cfp);
+ rb_control_frame_t *cfp = rb_vm_get_ruby_level_next_cfp(th, th->cfp);
if (cfp != 0) {
block = *RUBY_VM_GET_BLOCK_PTR_IN_CFP(cfp);