}
-void BlockResolver::visit(Block &block)
+void BlockResolver::enter(Block &block)
{
block.parent = current_block;
- TraversingVisitor::visit(block);
}
void BlockResolver::visit(InterfaceBlock &iface)
return block.parent ? block.parent : &block!=builtins ? builtins : 0;
}
-void VariableResolver::visit(Block &block)
+void VariableResolver::enter(Block &block)
{
- if(current_block!=&block)
- block.variables.clear();
-
- TraversingVisitor::visit(block);
+ block.variables.clear();
}
void VariableResolver::visit(VariableReference &var)
TraversingVisitor::visit(iface);
}
-void VariableResolver::visit(FunctionDeclaration &func)
-{
- SetForScope<Block *> set_block(current_block, &func.body);
- func.body.variables.clear();
- TraversingVisitor::visit(func);
-}
-
-void VariableResolver::visit(Iteration &iter)
-{
- SetForScope<Block *> set_block(current_block, &iter.body);
- iter.body.variables.clear();
- TraversingVisitor::visit(iter);
-}
-
void FunctionResolver::visit(FunctionCall &call)
{