From 3ac89867ceb4474c3be9794348d7bd5183305cfb Mon Sep 17 00:00:00 2001 From: John Hodge Date: Sat, 2 Apr 2016 12:32:36 +0800 Subject: Expand - Handle attributes on module-level macro invocations --- src/expand/mod.cpp | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) (limited to 'src/expand') diff --git a/src/expand/mod.cpp b/src/expand/mod.cpp index cfbfc2e7..416db81e 100644 --- a/src/expand/mod.cpp +++ b/src/expand/mod.cpp @@ -25,6 +25,12 @@ void Register_Synext_Macro(::std::string name, ::std::unique_ptr mo for(unsigned int i = 0; i < mod.macro_invs().size(); i ++ ) { auto& mi = mod.macro_invs()[i]; - DEBUG("> Macro invoke '"< Macro invoke " << mi); if( mi.name() != "" ) { // Move out of the module to avoid invalidation if a new macro invocation is added auto mi_owned = mv$(mi); - auto& attrs = mi.attrs(); + auto& attrs = mi_owned.attrs(); Expand_Attrs(attrs, stage_pre(is_early), [&](const auto& d, const auto& a){ d.handle(a, crate, mi_owned); }); auto ttl = Expand_Macro(is_early, crate, modstack, mod, mi_owned); -- cgit v1.2.3