@@ -197,6 +197,8 @@ Late::visit (AST::PathInExpression &expr)
// do we emit it in `get<Namespace::Labels>`?
auto value = ctx.values.resolve_path (expr.get_segments ());
+ if (!value.has_value ())
+ rust_unreachable (); // Should have been resolved earlier
ctx.map_usage (Usage (expr.get_node_id ()), Definition (*value));
}
@@ -25,6 +25,13 @@
namespace Rust {
namespace Resolver2_0 {
+void
+GlobbingVisitor::go (AST::Module *module)
+{
+ for (auto &i : module->get_items ())
+ visit (i);
+}
+
void
GlobbingVisitor::visit (AST::Module &module)
{
@@ -399,7 +406,7 @@ TopLevel::handle_use_glob (AST::SimplePath glob)
return false;
GlobbingVisitor gvisitor (ctx);
- gvisitor.visit (*result.value ());
+ gvisitor.go (result.value ());
return true;
}
@@ -33,6 +33,7 @@ class GlobbingVisitor : public AST::DefaultASTVisitor
public:
GlobbingVisitor (NameResolutionContext &ctx) : ctx (ctx) {}
+ void go (AST::Module *module);
void visit (AST::Module &module) override;
void visit (AST::MacroRulesDefinition ¯o) override;
void visit (AST::Function &function) override;