summaryrefslogtreecommitdiffstats
path: root/object.c
diff options
context:
space:
mode:
authorko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-02-16 12:36:49 +0000
committerko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-02-16 12:36:49 +0000
commit54634e74ab86e55a993cf8bcd90ce7c01a34df3b (patch)
tree497a34285070987477c8107f0295fc0936f81af2 /object.c
parenta0b05e98a7f2cb3e59cbd4934ee2e654f9f771fc (diff)
downloadruby-54634e74ab86e55a993cf8bcd90ce7c01a34df3b.tar.gz
ruby-54634e74ab86e55a993cf8bcd90ce7c01a34df3b.tar.xz
ruby-54634e74ab86e55a993cf8bcd90ce7c01a34df3b.zip
* object.c (rb_obj_ivar_set/get/defined): fix to check :@_v/C id.
* test/testunit/test_testcase.rb: fix to use instance_variable_get() to access @_result. git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@11763 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'object.c')
-rw-r--r--object.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/object.c b/object.c
index aa5e6b73f..f0138d6c2 100644
--- a/object.c
+++ b/object.c
@@ -1673,13 +1673,13 @@ rb_obj_public_methods(int argc, VALUE *argv, VALUE obj)
* fred.instance_variable_get(:@a) #=> "cat"
* fred.instance_variable_get("@b") #=> 99
*/
-
+#include "debug.h"
static VALUE
rb_obj_ivar_get(VALUE obj, VALUE iv)
{
ID id = rb_to_id(iv);
- if (!rb_is_instance_id(id)) {
+ if (!rb_is_instance_id(id) && !rb_is_instance2_id(id)) {
rb_name_error(id, "`%s' is not allowed as an instance variable name", rb_id2name(id));
}
return rb_ivar_get(obj, id);
@@ -1710,7 +1710,7 @@ rb_obj_ivar_set(VALUE obj, VALUE iv, VALUE val)
{
ID id = rb_to_id(iv);
- if (!rb_is_instance_id(id)) {
+ if (!rb_is_instance_id(id) && !rb_is_instance2_id(id)) {
rb_name_error(id, "`%s' is not allowed as an instance variable name", rb_id2name(id));
}
return rb_ivar_set(obj, id, val);
@@ -1739,7 +1739,7 @@ rb_obj_ivar_defined(VALUE obj, VALUE iv)
{
ID id = rb_to_id(iv);
- if (!rb_is_instance_id(id)) {
+ if (!rb_is_instance_id(id) && !rb_is_instance2_id(id)) {
rb_name_error(id, "`%s' is not allowed as an instance variable name", rb_id2name(id));
}
return rb_ivar_defined(obj, id);