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