diff --git a/ChangeLog b/ChangeLog index f94c868e89..50be216f14 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,9 @@ +Sat Dec 22 11:47:42 2007 Koichi Sasada + + * eval.c (rb_obj_instance_eval): use class of immediate objects. + + * test/ruby/test_eval.rb: fix a test. + Sat Dec 22 11:37:06 2007 NAKAMURA Usaku * encoding.c (rb_locale_charmap): win32 support. diff --git a/eval.c b/eval.c index 8a1ff85a00..3b59db95c8 100644 --- a/eval.c +++ b/eval.c @@ -1998,7 +1998,7 @@ rb_obj_instance_eval(int argc, VALUE *argv, VALUE self) VALUE klass; if (SPECIAL_CONST_P(self)) { - klass = Qnil; + klass = CLASS_OF(self); //klass = Qnil; } else { klass = rb_singleton_class(self); diff --git a/test/ruby/test_eval.rb b/test/ruby/test_eval.rb index af59cced49..6e39374a9c 100644 --- a/test/ruby/test_eval.rb +++ b/test/ruby/test_eval.rb @@ -341,7 +341,7 @@ class TestEval < Test::Unit::TestCase def test_cvar_scope_with_instance_eval Fixnum.class_eval "@@test_cvar_scope_with_instance_eval = 1" # depends on [ruby-dev:24229] @@test_cvar_scope_with_instance_eval = 4 - assert_equal(4, 1.instance_eval("@@test_cvar_scope_with_instance_eval"), "[ruby-dev:24223]") + assert_equal(1, 1.instance_eval("@@test_cvar_scope_with_instance_eval"), "[ruby-dev:24223]") Fixnum.__send__(:remove_class_variable, :@@test_cvar_scope_with_instance_eval) end