[前][次][番号順一覧][スレッド一覧]

ruby-changes:73846

From: Nobuyoshi <ko1@a...>
Date: Mon, 3 Oct 2022 23:38:32 +0900 (JST)
Subject: [ruby-changes:73846] cbd82f5250 (master): Cannot `define` from defined `Data` class again

https://git.ruby-lang.org/ruby.git/commit/?id=cbd82f5250

From cbd82f52502630e5298c8b82e8d52c59ee5454e1 Mon Sep 17 00:00:00 2001
From: Nobuyoshi Nakada <nobu@r...>
Date: Mon, 3 Oct 2022 23:28:01 +0900
Subject: Cannot `define` from defined `Data` class again

---
 struct.c               | 10 ++++++----
 test/ruby/test_data.rb |  2 ++
 2 files changed, 8 insertions(+), 4 deletions(-)

diff --git a/struct.c b/struct.c
index 9793133f80..ae24b5450d 100644
--- a/struct.c
+++ b/struct.c
@@ -384,10 +384,12 @@ setup_data(VALUE subclass, VALUE members) https://github.com/ruby/ruby/blob/trunk/struct.c#L384
     members = struct_set_members(subclass, members);
 
     rb_define_alloc_func(subclass, struct_alloc);
-    rb_define_singleton_method(subclass, "new", rb_data_s_new, -1);
-    rb_define_singleton_method(subclass, "[]", rb_data_s_new, -1);
-    rb_define_singleton_method(subclass, "members", rb_struct_s_members_m, 0);
-    rb_define_singleton_method(subclass, "inspect", rb_struct_s_inspect, 0); // FIXME: just a separate method?..
+    VALUE sclass = rb_singleton_class(subclass);
+    rb_undef_method(sclass, "define");
+    rb_define_method(sclass, "new", rb_data_s_new, -1);
+    rb_define_method(sclass, "[]", rb_data_s_new, -1);
+    rb_define_method(sclass, "members", rb_struct_s_members_m, 0);
+    rb_define_method(sclass, "inspect", rb_struct_s_inspect, 0); // FIXME: just a separate method?..
 
     len = RARRAY_LEN(members);
     for (i=0; i< len; i++) {
diff --git a/test/ruby/test_data.rb b/test/ruby/test_data.rb
index 0117cd22c5..f63b0236fb 100644
--- a/test/ruby/test_data.rb
+++ b/test/ruby/test_data.rb
@@ -14,6 +14,8 @@ class TestData < Test::Unit::TestCase https://github.com/ruby/ruby/blob/trunk/test/ruby/test_data.rb#L14
 
     # Because some code is shared with Struct, check we don't share unnecessary functionality
     assert_raise(TypeError) { Data.define(:foo, keyword_init: true) }
+
+    assert_not_respond_to(Data.define, :define, "Cannot define from defined Data class")
   end
 
   def test_define_edge_cases
-- 
cgit v1.2.1


--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/

[前][次][番号順一覧][スレッド一覧]