]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
gccrs: Fix ICE when compiling path which resolves to trait constant
authorPhilip Herron <herron.philip@googlemail.com>
Thu, 27 Mar 2025 16:32:21 +0000 (16:32 +0000)
committerPhilip Herron <philip.herron@embecosm.com>
Thu, 27 Mar 2025 18:07:48 +0000 (18:07 +0000)
Fixes Rust-GCC#3552

gcc/rust/ChangeLog:

* backend/rust-compile-resolve-path.cc (HIRCompileBase::query_compile): check for Expr trait
* hir/rust-hir-dump.cc (Dump::visit): expr is optional

gcc/testsuite/ChangeLog:

* rust/compile/issue-3552.rs: New test.

Signed-off-by: Philip Herron <herron.philip@googlemail.com>
gcc/rust/backend/rust-compile-resolve-path.cc
gcc/rust/hir/rust-hir-dump.cc
gcc/testsuite/rust/compile/issue-3552.rs [new file with mode: 0644]

index 9423951962f1b1019b81d6814faeb68db0331eab..d4901a44beada79949fc8063c39d96d12cf7d2bc 100644 (file)
@@ -301,6 +301,27 @@ HIRCompileBase::query_compile (HirId ref, TyTy::BaseType *lookup,
            trait->get_mappings ().get_defid (), &trait_ref);
          rust_assert (ok);
 
+         if (trait_item.value ()->get_item_kind ()
+             == HIR::TraitItem::TraitItemKind::CONST)
+           {
+             auto &c
+               = *static_cast<HIR::TraitItemConst *> (trait_item.value ());
+             if (!c.has_expr ())
+               {
+                 rich_location r (line_table, expr_locus);
+                 r.add_range (trait->get_locus ());
+                 r.add_range (c.get_locus ());
+                 rust_error_at (r, "no default expression on trait constant");
+                 return error_mark_node;
+               }
+
+             return CompileExpr::Compile (c.get_expr (), ctx);
+           }
+
+         if (trait_item.value ()->get_item_kind ()
+             != HIR::TraitItem::TraitItemKind::FUNC)
+           return error_mark_node;
+
          // the type resolver can only resolve type bounds to their trait
          // item so its up to us to figure out if this path should resolve
          // to an trait-impl-block-item or if it can be defaulted to the
index 13ad7fa6ab32f9c1e40dc34302235be0cab82678..983922c73e31df1f96a1b31f9fd15443bde0447d 100644 (file)
@@ -1932,7 +1932,9 @@ Dump::visit (TraitItemConst &e)
 
   put_field ("name", e.get_name ().as_string ());
   visit_field ("type", e.get_type ());
-  visit_field ("expr", e.get_expr ());
+  if (e.has_expr ())
+    visit_field ("expr", e.get_expr ());
+
   end ("TraitItemConst");
 }
 
diff --git a/gcc/testsuite/rust/compile/issue-3552.rs b/gcc/testsuite/rust/compile/issue-3552.rs
new file mode 100644 (file)
index 0000000..9a4451b
--- /dev/null
@@ -0,0 +1,14 @@
+trait Foo {
+    const BAR: u32;
+}
+
+const TRAIT_REF_BAR: u32 = <Foo>::BAR;
+// { dg-error "no default expression on trait constant" "" { target *-*-* } .-1 }
+
+struct GlobalTraitRef;
+
+impl Foo for GlobalTraitRef {
+    const BAR: u32 = TRAIT_REF_BAR;
+}
+
+fn main() {}