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/