glsl: Make ir_validate actually visit ir_if nodes.
There is no ir_hierarchical_visitor::visit(ir_if *) method, since ir_if is not a leaf node. Instead, there are visit_enter and visit_leave methods. Use visit_enter arbitrarily (either would work fine, though visit_enter will catch errors sooner). Found thanks to a warning emitted by Clang. Reviewed-by: Ian Romanick <ian.d.romanick@intel.com> Signed-off-by: Kenneth Graunke <kenneth@whitecape.org>
This commit is contained in:
@@ -59,7 +59,8 @@ public:
|
||||
|
||||
virtual ir_visitor_status visit(ir_variable *v);
|
||||
virtual ir_visitor_status visit(ir_dereference_variable *ir);
|
||||
virtual ir_visitor_status visit(ir_if *ir);
|
||||
|
||||
virtual ir_visitor_status visit_enter(ir_if *ir);
|
||||
|
||||
virtual ir_visitor_status visit_leave(ir_loop *ir);
|
||||
virtual ir_visitor_status visit_enter(ir_function *ir);
|
||||
@@ -102,7 +103,7 @@ ir_validate::visit(ir_dereference_variable *ir)
|
||||
}
|
||||
|
||||
ir_visitor_status
|
||||
ir_validate::visit(ir_if *ir)
|
||||
ir_validate::visit_enter(ir_if *ir)
|
||||
{
|
||||
if (ir->condition->type != glsl_type::bool_type) {
|
||||
printf("ir_if condition %s type instead of bool.\n",
|
||||
|
Reference in New Issue
Block a user