ExpandVisitor::visit (AST::Module &module)
{
if (module.get_kind () == AST::Module::ModuleKind::LOADED)
- for (auto &item : module.get_items ())
- visit (item);
+ {
+ visit_inner_attrs (module);
+ for (auto &item : module.get_items ())
+ visit (item);
+ }
}
void
void
ExpandVisitor::visit (AST::Function &function)
{
+ visit_inner_using_attrs (function,
+ function.get_definition ()->get_inner_attrs ());
for (auto ¶m : function.get_generic_params ())
visit (param);
void
ExpandVisitor::visit (AST::InherentImpl &impl)
{
+ visit_inner_attrs (impl);
// just expand sub-stuff - can't actually strip generic params themselves
for (auto &generic : impl.get_generic_params ())
visit (generic);
void
ExpandVisitor::visit (AST::TraitImpl &impl)
{
+ visit_inner_attrs (impl);
// just expand sub-stuff - can't actually strip generic params themselves
for (auto ¶m : impl.get_generic_params ())
visit (param);
void
ExpandVisitor::visit (AST::ExternBlock &block)
{
+ visit_inner_attrs (block);
std::function<std::unique_ptr<AST::ExternalItem> (AST::SingleASTNode)>
extractor
= [] (AST::SingleASTNode node) { return node.take_external_item (); };
visit (type.get_return_type ());
}
+template <typename T>
+void
+ExpandVisitor::expand_inner_attribute (T &item, AST::SimplePath &path)
+{
+ // TODO: Warn about instability ?
+ // FIXME: Implement expansion for that particular path
+}
+
+template <typename T>
+void
+ExpandVisitor::visit_inner_using_attrs (T &item,
+ std::vector<AST::Attribute> &attrs)
+{
+ for (auto it = attrs.begin (); it != attrs.end (); /* erase => No increment*/)
+ {
+ auto current = *it;
+
+ it = attrs.erase (it);
+ expand_inner_attribute (item, current.get_path ());
+ }
+}
+
+template <typename T>
+void
+ExpandVisitor::visit_inner_attrs (T &item)
+{
+ visit_inner_using_attrs (item, item.get_inner_attrs ());
+}
+
template <typename T>
void
ExpandVisitor::expand_derive (const T &item,
void visit (AST::InferredType &) override;
void visit (AST::BareFunctionType &type) override;
+ template <typename T>
+ void expand_inner_attribute (T &item, AST::SimplePath &Path);
+
+ template <typename T>
+ void visit_inner_using_attrs (T &item, std::vector<AST::Attribute> &attrs);
+
+ template <typename T> void visit_inner_attrs (T &item);
+
bool is_derive (AST::Attribute &attr);
template <typename T>