aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorArthur Cohen <arthur.cohen@embecosm.com>2023-05-22 11:22:45 +0200
committerArthur Cohen <arthur.cohen@embecosm.com>2024-01-16 18:37:21 +0100
commit917914509f467c0f333575914f5fbb9dc78a39f7 (patch)
treede56a2fe5aa63a35825b8d634ca68d7b7f26866e /gcc
parent1af4d0e6078e048b88aa5e1547cf1e097952b621 (diff)
downloadgcc-917914509f467c0f333575914f5fbb9dc78a39f7.zip
gcc-917914509f467c0f333575914f5fbb9dc78a39f7.tar.gz
gcc-917914509f467c0f333575914f5fbb9dc78a39f7.tar.bz2
gccrs: enr: Cleanup #[macro_use] accumulation
gcc/rust/ChangeLog: * resolve/rust-early-name-resolver.cc (EarlyNameResolver::go): Cleanup order of calls when accumulating #[macro_use] macros. (EarlyNameResolver::visit): Likewise.
Diffstat (limited to 'gcc')
-rw-r--r--gcc/rust/resolve/rust-early-name-resolver.cc38
1 files changed, 16 insertions, 22 deletions
diff --git a/gcc/rust/resolve/rust-early-name-resolver.cc b/gcc/rust/resolve/rust-early-name-resolver.cc
index 259b2d4..17ec10c 100644
--- a/gcc/rust/resolve/rust-early-name-resolver.cc
+++ b/gcc/rust/resolve/rust-early-name-resolver.cc
@@ -85,18 +85,15 @@ EarlyNameResolver::go (AST::Crate &crate)
scoped (crate.get_node_id (), [&items, &new_items, this] {
for (auto &&item : items)
{
+ auto new_macros = std::vector<std::unique_ptr<AST::Item>> ();
+
if (item->get_ast_kind () == AST::Kind::MODULE)
- {
- auto macros = accumulate_escaped_macros (
- *static_cast<AST::Module *> (item.get ()));
- new_items.emplace_back (std::move (item));
- std::move (macros.begin (), macros.end (),
- std::back_inserter (new_items));
- }
- else
- {
- new_items.emplace_back (std::move (item));
- }
+ new_macros = accumulate_escaped_macros (
+ *static_cast<AST::Module *> (item.get ()));
+
+ new_items.emplace_back (std::move (item));
+ std::move (new_macros.begin (), new_macros.end (),
+ std::back_inserter (new_items));
}
});
@@ -636,18 +633,15 @@ EarlyNameResolver::visit (AST::Module &module)
scoped (module.get_node_id (), [&items, &new_items, this] {
for (auto &&item : items)
{
+ auto new_macros = std::vector<std::unique_ptr<AST::Item>> ();
+
if (item->get_ast_kind () == AST::Kind::MODULE)
- {
- auto macros = accumulate_escaped_macros (
- *static_cast<AST::Module *> (item.get ()));
- new_items.emplace_back (std::move (item));
- std::move (macros.begin (), macros.end (),
- std::back_inserter (new_items));
- }
- else
- {
- new_items.emplace_back (std::move (item));
- }
+ new_macros = accumulate_escaped_macros (
+ *static_cast<AST::Module *> (item.get ()));
+
+ new_items.emplace_back (std::move (item));
+ std::move (new_macros.begin (), new_macros.end (),
+ std::back_inserter (new_items));
}
});