From f20d5de466def02ec88e2889e80e24e736b0ade4 Mon Sep 17 00:00:00 2001 From: Jeff Bezanson Date: Thu, 24 Feb 2022 17:08:37 -0500 Subject: [PATCH] fix #43411, wrapped `NamedTuple` can be bitstype more often (#44311) --- src/jltypes.c | 2 ++ test/core.jl | 6 ++++++ 2 files changed, 8 insertions(+) diff --git a/src/jltypes.c b/src/jltypes.c index a24e9f7e488bd..e19b4c536d94d 100644 --- a/src/jltypes.c +++ b/src/jltypes.c @@ -61,6 +61,8 @@ static int layout_uses_free_typevars(jl_value_t *v, jl_typeenv_t *env) jl_datatype_t *dt = (jl_datatype_t*)v; if (dt->layout || dt->isconcretetype || !dt->name->mayinlinealloc) return 0; + if (dt->name == jl_namedtuple_typename) + return layout_uses_free_typevars(jl_tparam0(dt), env) || layout_uses_free_typevars(jl_tparam1(dt), env); jl_svec_t *types = jl_get_fieldtypes(dt); size_t i, l = jl_svec_len(types); for (i = 0; i < l; i++) { diff --git a/test/core.jl b/test/core.jl index 43d6da062560b..6dbd8f3d9fa0e 100644 --- a/test/core.jl +++ b/test/core.jl @@ -7324,6 +7324,12 @@ end @test isbitstype(X41654) @test ('a'=>X41654(),)[1][2] isa X41654 +# issue #43411 +struct A43411{S, T} + x::NamedTuple{S, T} +end +@test isbitstype(A43411{(:a,), Tuple{Int}}) + # Issue #34206/34207 function mre34206(a, n) va = view(a, :)