From f92db3dd73328b9743a91654453e51cdef19ea4c Mon Sep 17 00:00:00 2001 From: nobu Date: Wed, 12 Dec 2012 04:40:55 +0000 Subject: [PATCH] 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 --- ChangeLog | 5 ++++ test/ruby/test_module.rb | 63 ++++++++++++++++++++++++++++++++++++++++ vm_insnhelper.c | 2 ++ 3 files changed, 70 insertions(+) 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 + + * 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 * 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); }