diff options
| -rw-r--r-- | src/ast/macro.hpp | 5 | ||||
| -rw-r--r-- | src/expand/mod.cpp | 10 | ||||
| -rw-r--r-- | src/include/synext.hpp | 17 | 
3 files changed, 21 insertions, 11 deletions
| diff --git a/src/ast/macro.hpp b/src/ast/macro.hpp index 733023ca..85f2dea2 100644 --- a/src/ast/macro.hpp +++ b/src/ast/macro.hpp @@ -56,7 +56,10 @@ public:      SERIALISABLE_PROTOTYPES();      friend ::std::ostream& operator<<(::std::ostream& os, const MacroInvocation& x) { -        os << x.m_attrs << x.m_macro_name << "! " << x.m_ident << x.m_input; +        os << x.m_attrs; +        if(x.m_attrs.m_items.size() > 0) +            os << " "; +        os << x.m_macro_name << "! " << x.m_ident << x.m_input;          return os;      }  }; 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<ExpandProcMacro      g_macros[name] = mv$(handler);  } + +void ExpandDecorator::unexpected(const AST::MetaItem& mi, const char* loc_str) const +{ +    ERROR(Span(), E0000, "Unexpected attribute " << mi.name() << " on " << loc_str); +} +  namespace {      AttrStage stage_pre(bool is_early) {          return (is_early ? AttrStage::EarlyPre : AttrStage::LatePre); @@ -459,14 +465,14 @@ void Expand_Mod(bool is_early, ::AST::Crate& crate, LList<const AST::Module*> mo      for(unsigned int i = 0; i < mod.macro_invs().size(); i ++ )      {          auto& mi = mod.macro_invs()[i]; -        DEBUG("> Macro invoke '"<<mi.name()<<"'"); +        DEBUG("> 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); diff --git a/src/include/synext.hpp b/src/include/synext.hpp index 0b9ec3f1..4320fceb 100644 --- a/src/include/synext.hpp +++ b/src/include/synext.hpp @@ -44,22 +44,23 @@ enum class AttrStage  class ExpandDecorator  { +    void unexpected(const AST::MetaItem& mi, const char* loc_str) const;  public:      virtual AttrStage   stage() const = 0; -    virtual void    handle(const AST::MetaItem& mi, AST::Crate& crate) const {} -    virtual void    handle(const AST::MetaItem& mi, AST::Crate& crate, AST::MacroInvocation& mac) const {} -    virtual void    handle(const AST::MetaItem& mi, AST::Crate& crate, const AST::Path& path, AST::Module& mod, AST::Item&i) const {} +    virtual void    handle(const AST::MetaItem& mi, AST::Crate& crate) const { unexpected(mi, "crate"); } +    virtual void    handle(const AST::MetaItem& mi, AST::Crate& crate, AST::MacroInvocation& mac) const { unexpected(mi, "macro invocation"); } +    virtual void    handle(const AST::MetaItem& mi, AST::Crate& crate, const AST::Path& path, AST::Module& mod, AST::Item&i) const { unexpected(mi, "item"); }      // NOTE: To delete, clear the name -    virtual void    handle(const AST::MetaItem& mi, AST::Crate& crate, ::AST::StructItem& si) const {} +    virtual void    handle(const AST::MetaItem& mi, AST::Crate& crate, ::AST::StructItem& si) const { unexpected(mi, "struct item"); }      // NOTE: To delete, make the type invalid -    virtual void    handle(const AST::MetaItem& mi, AST::Crate& crate, ::AST::TupleItem& si) const {} +    virtual void    handle(const AST::MetaItem& mi, AST::Crate& crate, ::AST::TupleItem& si) const { unexpected(mi, "tuple item"); }      // NOTE: To delete, clear the name -    virtual void    handle(const AST::MetaItem& mi, AST::Crate& crate, ::AST::EnumVariant& ev) const {} +    virtual void    handle(const AST::MetaItem& mi, AST::Crate& crate, ::AST::EnumVariant& ev) const { unexpected(mi, "enum variant"); } -    virtual void    handle(const AST::MetaItem& mi, AST::Crate& crate, ::std::unique_ptr<AST::ExprNode>& expr) const {} +    virtual void    handle(const AST::MetaItem& mi, AST::Crate& crate, ::std::unique_ptr<AST::ExprNode>& expr) const { unexpected(mi, "expression"); }      // NOTE: To delete, clear the patterns vector -    virtual void    handle(const AST::MetaItem& mi, AST::Crate& crate, ::AST::ExprNode_Match_Arm& expr) const {} +    virtual void    handle(const AST::MetaItem& mi, AST::Crate& crate, ::AST::ExprNode_Match_Arm& expr) const { unexpected(mi, "match arm"); }  };  class ExpandProcMacro | 
