mirror of
https://github.com/ruby/ruby.git
synced 2026-01-26 12:14:51 +00:00
merge revision(s) 2e7e78cd590d20aa9d41422e96302f3edd73f623: [Backport #21440]
[Bug #21440] Stop caching member list in frozen Data/Struct class
This commit is contained in:
parent
de512b7a3d
commit
a976792832
3
struct.c
3
struct.c
@ -52,7 +52,8 @@ struct_ivar_get(VALUE c, ID id)
|
||||
RUBY_ASSERT(RB_TYPE_P(c, T_CLASS));
|
||||
ivar = rb_attr_get(c, id);
|
||||
if (!NIL_P(ivar)) {
|
||||
return rb_ivar_set(orig, id, ivar);
|
||||
if (!OBJ_FROZEN(orig)) rb_ivar_set(orig, id, ivar);
|
||||
return ivar;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -280,4 +280,10 @@ class TestData < Test::Unit::TestCase
|
||||
assert_not_same(test, loaded)
|
||||
assert_predicate(loaded, :frozen?)
|
||||
end
|
||||
|
||||
def test_frozen_subclass
|
||||
test = Class.new(Data.define(:a)).freeze.new(a: 0)
|
||||
assert_kind_of(Data, test)
|
||||
assert_equal([:a], test.members)
|
||||
end
|
||||
end
|
||||
|
||||
@ -548,6 +548,12 @@ module TestStruct
|
||||
CODE
|
||||
end
|
||||
|
||||
def test_frozen_subclass
|
||||
test = Class.new(@Struct.new(:a)).freeze.new(a: 0)
|
||||
assert_kind_of(@Struct, test)
|
||||
assert_equal([:a], test.members)
|
||||
end
|
||||
|
||||
class TopStruct < Test::Unit::TestCase
|
||||
include TestStruct
|
||||
|
||||
|
||||
@ -11,7 +11,7 @@
|
||||
# define RUBY_VERSION_MINOR RUBY_API_VERSION_MINOR
|
||||
#define RUBY_VERSION_TEENY 8
|
||||
#define RUBY_RELEASE_DATE RUBY_RELEASE_YEAR_STR"-"RUBY_RELEASE_MONTH_STR"-"RUBY_RELEASE_DAY_STR
|
||||
#define RUBY_PATCHLEVEL 161
|
||||
#define RUBY_PATCHLEVEL 162
|
||||
|
||||
#include "ruby/version.h"
|
||||
#include "ruby/internal/abi.h"
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user