aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorOwen Avery <powerboat9.gamer@gmail.com>2025-02-18 21:20:45 -0500
committerArthur Cohen <arthur.cohen@embecosm.com>2025-03-24 13:07:11 +0100
commit9ddf6be21e06e20c779ac5a49c3fda10bd04920c (patch)
tree30c8e5d3bc31cf226928ac831c012eeb066ab435 /gcc
parentb0dff76ede4ef853d87e090573d1df1a1f236207 (diff)
downloadgcc-9ddf6be21e06e20c779ac5a49c3fda10bd04920c.zip
gcc-9ddf6be21e06e20c779ac5a49c3fda10bd04920c.tar.gz
gcc-9ddf6be21e06e20c779ac5a49c3fda10bd04920c.tar.bz2
gccrs: nr2.0: Implement macro_use for modules
gcc/rust/ChangeLog: * resolve/rust-early-name-resolver-2.0.cc: Include rust-attribute-values.h. (Early::visit): If a module has a macro_use attribute, avoid pushing a new textual macro scope. gcc/testsuite/ChangeLog: * rust/compile/nr2/exclude: Remove entries. Signed-off-by: Owen Avery <powerboat9.gamer@gmail.com>
Diffstat (limited to 'gcc')
-rw-r--r--gcc/rust/resolve/rust-early-name-resolver-2.0.cc18
-rw-r--r--gcc/testsuite/rust/compile/nr2/exclude3
2 files changed, 16 insertions, 5 deletions
diff --git a/gcc/rust/resolve/rust-early-name-resolver-2.0.cc b/gcc/rust/resolve/rust-early-name-resolver-2.0.cc
index d1e7ee0..764be45 100644
--- a/gcc/rust/resolve/rust-early-name-resolver-2.0.cc
+++ b/gcc/rust/resolve/rust-early-name-resolver-2.0.cc
@@ -22,6 +22,7 @@
#include "rust-toplevel-name-resolver-2.0.h"
#include "rust-attributes.h"
#include "rust-finalize-imports-2.0.h"
+#include "rust-attribute-values.h"
namespace Rust {
namespace Resolver2_0 {
@@ -227,11 +228,24 @@ Early::visit (AST::BlockExpr &block)
void
Early::visit (AST::Module &module)
{
- textual_scope.push ();
+ bool is_macro_use = false;
+
+ for (const auto &attr : module.get_outer_attrs ())
+ {
+ if (attr.get_path ().as_string () == Values::Attributes::MACRO_USE)
+ {
+ is_macro_use = true;
+ break;
+ }
+ }
+
+ if (!is_macro_use)
+ textual_scope.push ();
DefaultResolver::visit (module);
- textual_scope.pop ();
+ if (!is_macro_use)
+ textual_scope.pop ();
}
void
diff --git a/gcc/testsuite/rust/compile/nr2/exclude b/gcc/testsuite/rust/compile/nr2/exclude
index 6e17eca..f74c2ac 100644
--- a/gcc/testsuite/rust/compile/nr2/exclude
+++ b/gcc/testsuite/rust/compile/nr2/exclude
@@ -24,12 +24,9 @@ lookup_err1.rs
macros/mbe/macro43.rs
macros/mbe/macro44.rs
macros/mbe/macro6.rs
-macros/mbe/macro_use1.rs
multiple_bindings1.rs
multiple_bindings2.rs
-nested_macro_use1.rs
nested_macro_use2.rs
-nested_macro_use3.rs
not_find_value_in_scope.rs
privacy5.rs
privacy8.rs