summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarc-Andre Lafortune <[email protected]>2020-09-14 15:15:28 -0400
committerMarc-AndrĂ© Lafortune <[email protected]>2020-09-14 16:10:37 -0400
commit60f5d384820a4b07f739d32c2233b1dbc74a726a (patch)
treef2c03842f3ec17f0ec50c4904e5d55f958c0b1d6
parent125605abd949b23a8a95e1cc95f7d435efc17290 (diff)
[ruby/ostruct] Fix dup/clone
Notes
Notes: Merged: https://github.com/ruby/ruby/pull/3541
-rw-r--r--lib/ostruct.rb10
-rw-r--r--spec/ruby/library/openstruct/frozen_spec.rb2
2 files changed, 9 insertions, 3 deletions
diff --git a/lib/ostruct.rb b/lib/ostruct.rb
index f403f63bdb..6f8f255511 100644
--- a/lib/ostruct.rb
+++ b/lib/ostruct.rb
@@ -130,10 +130,14 @@ class OpenStruct
end
# Duplicates an OpenStruct object's Hash table.
- def initialize_copy(orig) # :nodoc:
- orig.table.each_key{|key| new_ostruct_member!(key)}
+ private def initialize_clone(orig) # :nodoc:
+ super # clones the singleton class for us
+ @table = @table.dup unless @table.frozen?
+ end
+
+ private def initialize_dup(orig) # :nodoc:
super
- @table = @table.dup
+ initialize(@table)
end
#
diff --git a/spec/ruby/library/openstruct/frozen_spec.rb b/spec/ruby/library/openstruct/frozen_spec.rb
index 63767bb54d..c14a4bac55 100644
--- a/spec/ruby/library/openstruct/frozen_spec.rb
+++ b/spec/ruby/library/openstruct/frozen_spec.rb
@@ -24,6 +24,7 @@ describe "OpenStruct.new when frozen" do
it "creates a frozen clone" do
f = @os.clone
+ f.frozen?.should == true
f.age.should == 70
->{ f.age = 0 }.should raise_error( RuntimeError )
->{ f.state = :newer }.should raise_error( RuntimeError )
@@ -31,6 +32,7 @@ describe "OpenStruct.new when frozen" do
it "creates an unfrozen dup" do
d = @os.dup
+ d.frozen?.should == false
d.age.should == 70
d.age = 42
d.age.should == 42