summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2012-12-12 04:40:55 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2012-12-12 04:40:55 +0000
commitf92db3dd73328b9743a91654453e51cdef19ea4c (patch)
treeeddd1dd771d1dba54421c1914ddcc7d5d69a44e4
parentdcb6e7330699e2b4b476ab5caff8e3d0508c500c (diff)
vm_insnhelper.c: no warnings for non-object
* vm_insnhelper.c (vm_getivar): no uninitialized instance variables warnings for non-object if attr method. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@38337 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog5
-rw-r--r--test/ruby/test_module.rb63
-rw-r--r--vm_insnhelper.c2
3 files changed, 70 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index 6790af5d0e..59fe229816 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Wed Dec 12 13:40:52 2012 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * vm_insnhelper.c (vm_getivar): no uninitialized instance variables
+ warnings for non-object if attr method.
+
Wed Dec 12 06:43:37 2012 Benoit Daloze <eregontp@gmail.com>
* iseq.c (rb_iseq_parameters): fix limit for optional arguments.
diff --git a/test/ruby/test_module.rb b/test/ruby/test_module.rb
index 6cdd832e4d..b2e2e8049d 100644
--- a/test/ruby/test_module.rb
+++ b/test/ruby/test_module.rb
@@ -1513,4 +1513,67 @@ class TestModule < Test::Unit::TestCase
end
end
end
+
+ class AttrTest
+ class << self
+ attr_accessor :cattr
+ end
+ attr_accessor :iattr
+ def ivar
+ @ivar
+ end
+ end
+
+ def test_uninitialized_instance_variable
+ a = AttrTest.new
+ stderr = EnvUtil.verbose_warning do
+ assert_nil(a.ivar)
+ end
+ assert_match(/instance variable @ivar not initialized/, stderr)
+ a.instance_variable_set(:@ivar, 42)
+ stderr = EnvUtil.verbose_warning do
+ assert_equal(42, a.ivar)
+ end
+ assert_equal("", stderr)
+ end
+
+ def test_uninitialized_attr
+ a = AttrTest.new
+ stderr = EnvUtil.verbose_warning do
+ assert_nil(a.iattr)
+ end
+ assert_equal("", stderr)
+ a.iattr = 42
+ stderr = EnvUtil.verbose_warning do
+ assert_equal(42, a.iattr)
+ end
+ assert_equal("", stderr)
+ end
+
+ def test_uninitialized_attr_class
+ stderr = EnvUtil.verbose_warning do
+ assert_nil(AttrTest.cattr)
+ end
+ assert_equal("", stderr)
+ AttrTest.cattr = 42
+ stderr = EnvUtil.verbose_warning do
+ assert_equal(42, AttrTest.cattr)
+ end
+ assert_equal("", stderr)
+ end
+
+ def test_uninitialized_attr_non_object
+ a = Class.new(Array) do
+ attr_accessor :iattr
+ end.new
+ stderr = EnvUtil.verbose_warning do
+ assert_nil(a.iattr)
+ end
+ assert_equal("", stderr)
+ a.iattr = 42
+ stderr = EnvUtil.verbose_warning do
+ assert_equal(42, a.iattr)
+ end
+ assert_equal("", stderr)
+ end
end
diff --git a/vm_insnhelper.c b/vm_insnhelper.c
index 294369504a..caaab54e1d 100644
--- a/vm_insnhelper.c
+++ b/vm_insnhelper.c
@@ -538,6 +538,8 @@ vm_getivar(VALUE obj, ID id, IC ic, rb_call_info_t *ci, int is_attr)
return val;
}
#endif /* USE_IC_FOR_IVAR */
+ if (is_attr)
+ return rb_attr_get(obj, id);
return rb_ivar_get(obj, id);
}