From 4ec86dcc5761a3eaca546ffe121c9d03d7e1e0cd Mon Sep 17 00:00:00 2001 From: nobu Date: Wed, 3 Nov 2010 05:17:25 +0000 Subject: [PATCH] * lib/ostruct.rb (OpenStruct#delete_field): also undefine accessor methods. [ruby-core:33010] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@29677 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 +++++ lib/ostruct.rb | 4 +++- test/ostruct/test_ostruct.rb | 13 +++++++++++++ 3 files changed, 21 insertions(+), 1 deletion(-) diff --git a/ChangeLog b/ChangeLog index de1e815bd8..8d18179a40 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Wed Nov 3 14:17:18 2010 Nobuyoshi Nakada + + * lib/ostruct.rb (OpenStruct#delete_field): also undefine + accessor methods. [ruby-core:33010] + Wed Nov 3 14:13:46 2010 Nobuyoshi Nakada * string.c (rb_enc_cr_str_buf_cat): concatenation of valid diff --git a/lib/ostruct.rb b/lib/ostruct.rb index aea0c8e124..e50da65181 100644 --- a/lib/ostruct.rb +++ b/lib/ostruct.rb @@ -107,7 +107,9 @@ class OpenStruct # Remove the named field from the object. # def delete_field(name) - @table.delete name.to_sym + sym = name.to_sym + @table.delete sym + singleton_class.__send__(:remove_method, sym, "#{name}=") end InspectKey = :__inspect_key__ # :nodoc: diff --git a/test/ostruct/test_ostruct.rb b/test/ostruct/test_ostruct.rb index d92092339a..5c83bfd2a2 100644 --- a/test/ostruct/test_ostruct.rb +++ b/test/ostruct/test_ostruct.rb @@ -48,4 +48,17 @@ class TC_OpenStruct < Test::Unit::TestCase o.freeze assert_raise(TypeError, '[ruby-core:22559]') {o.a = 1764} end + + def test_delete_field + bug = '[ruby-core:33010]' + o = OpenStruct.new + assert_not_respond_to(o, :a) + assert_not_respond_to(o, :a=) + o.a = 'a' + assert_respond_to(o, :a) + assert_respond_to(o, :a=) + o.delete_field :a + assert_not_respond_to(o, :a, bug) + assert_not_respond_to(o, :a=, bug) + end end