From: Owen Avery Date: Thu, 29 Feb 2024 01:19:04 +0000 (-0500) Subject: gccrs: Visit constant items without expressions properly X-Git-Tag: basepoints/gcc-16~1447 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=d6e6d2b3df75690de5648d23a5d6a1eb88feaaf9;p=thirdparty%2Fgcc.git gccrs: Visit constant items without expressions properly gcc/rust/ChangeLog: * resolve/rust-default-resolver.cc (DefaultResolver::visit): Verify constant item has expression before attempting to visit the later. Signed-off-by: Owen Avery --- diff --git a/gcc/rust/resolve/rust-default-resolver.cc b/gcc/rust/resolve/rust-default-resolver.cc index b206c5fc2cd..50625bab956 100644 --- a/gcc/rust/resolve/rust-default-resolver.cc +++ b/gcc/rust/resolve/rust-default-resolver.cc @@ -449,13 +449,16 @@ DefaultResolver::visit (AST::EnumItemDiscriminant &item) void DefaultResolver::visit (AST::ConstantItem &item) { - auto expr_vis = [this, &item] () { - item.get_expr ().accept_vis (*this); - visit (item.get_type ()); - }; + if (item.has_expr ()) + { + auto expr_vis = [this, &item] () { + item.get_expr ().accept_vis (*this); + visit (item.get_type ()); + }; - // FIXME: Why do we need a Rib here? - ctx.scoped (Rib::Kind::Item, item.get_node_id (), expr_vis); + // FIXME: Why do we need a Rib here? + ctx.scoped (Rib::Kind::Item, item.get_node_id (), expr_vis); + } } void