From: Pierre-Emmanuel Patry <[email protected]>

Every wildcard should be considered different and no error should be
emitted when multiple wildcards are used within the same rib.

gcc/rust/ChangeLog:

        * resolve/rust-toplevel-name-resolver-2.0.cc(TopLevel::visit): Insert
        constant item only if now wildcard.

gcc/testsuite/ChangeLog:

        * rust/compile/wildcard_items.rs: New test.

Signed-off-by: Pierre-Emmanuel Patry <[email protected]>
---
 .../resolve/rust-toplevel-name-resolver-2.0.cc     |  5 +++--
 gcc/testsuite/rust/compile/wildcard_items.rs       | 14 ++++++++++++++
 2 files changed, 17 insertions(+), 2 deletions(-)
 create mode 100644 gcc/testsuite/rust/compile/wildcard_items.rs

diff --git a/gcc/rust/resolve/rust-toplevel-name-resolver-2.0.cc 
b/gcc/rust/resolve/rust-toplevel-name-resolver-2.0.cc
index 98245846d43..67a8c52d1de 100644
--- a/gcc/rust/resolve/rust-toplevel-name-resolver-2.0.cc
+++ b/gcc/rust/resolve/rust-toplevel-name-resolver-2.0.cc
@@ -367,8 +367,9 @@ TopLevel::visit (AST::Union &union_item)
 void
 TopLevel::visit (AST::ConstantItem &const_item)
 {
-  insert_or_error_out (const_item.get_identifier (), const_item,
-                      Namespace::Values);
+  if (const_item.get_identifier ().as_string () != 
Values::Keywords::UNDERSCORE)
+    insert_or_error_out (const_item.get_identifier (), const_item,
+                        Namespace::Values);
 
   DefaultResolver::visit (const_item);
 }
diff --git a/gcc/testsuite/rust/compile/wildcard_items.rs 
b/gcc/testsuite/rust/compile/wildcard_items.rs
new file mode 100644
index 00000000000..8ce4733c134
--- /dev/null
+++ b/gcc/testsuite/rust/compile/wildcard_items.rs
@@ -0,0 +1,14 @@
+#![feature(lang_items)]
+#![feature(no_core)]
+#![no_core]
+
+macro_rules! assert {
+    ($cond:expr $(,)?) => {{ /* compiler built-in */ }};
+    ($cond:expr, $($arg:tt)+) => {{ /* compiler built-in */ }};
+}
+
+#[lang = "sized"]
+trait Sized {}
+
+const _: () = assert!(true);
+const _: () = assert!(true);
-- 
2.50.1

Reply via email to