diff options
author | Arthur Cohen <arthur.cohen@embecosm.com> | 2023-05-22 11:22:45 +0200 |
---|---|---|
committer | Arthur Cohen <arthur.cohen@embecosm.com> | 2024-01-16 18:37:21 +0100 |
commit | 917914509f467c0f333575914f5fbb9dc78a39f7 (patch) | |
tree | de56a2fe5aa63a35825b8d634ca68d7b7f26866e | |
parent | 1af4d0e6078e048b88aa5e1547cf1e097952b621 (diff) | |
download | gcc-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.
-rw-r--r-- | gcc/rust/resolve/rust-early-name-resolver.cc | 38 |
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)); } }); |