expr->visit(*this);
}
-void TraversingVisitor::visit(ParenthesizedExpression &parexpr)
-{
- visit(parexpr.expression);
-}
-
void TraversingVisitor::visit(MemberAccess &memacc)
{
visit(memacc.left);
visit(assign.right);
}
+void TraversingVisitor::visit(TernaryExpression &ternary)
+{
+ visit(ternary.condition);
+ visit(ternary.true_expr);
+ visit(ternary.false_expr);
+}
+
void TraversingVisitor::visit(FunctionCall &call)
{
for(NodeArray<Expression>::iterator i=call.arguments.begin(); i!=call.arguments.end(); ++i)
void TraversingVisitor::visit(InterfaceBlock &iface)
{
+ if(iface.layout)
+ iface.layout->visit(*this);
if(iface.members)
iface.members->visit(*this);
}
{
if(to_remove->count(&iface))
{
- remove_from_map(stage->interface_blocks, iface.interface+iface.name, iface);
+ remove_from_map(stage->interface_blocks, format("%s %s", iface.interface, iface.block_name), iface);
if(!iface.instance_name.empty())
- remove_from_map(stage->interface_blocks, "_"+iface.instance_name, iface);
+ remove_from_map(stage->interface_blocks, iface.instance_name, iface);
}
SetFlag set_recursive(recursive_remove, recursive_remove || to_remove->count(&iface));
TraversingVisitor::visit(iface);
void NodeRemover::visit(FunctionDeclaration &func)
{
if(to_remove->count(&func))
+ {
remove_from_map(stage->functions, func.name, func);
+ if(!func.signature.empty())
+ remove_from_map(stage->functions, func.name+func.signature, func);
+ }
TraversingVisitor::visit(func);
}