From: Kenneth Graunke Date: Wed, 18 Aug 2010 20:54:50 +0000 (-0700) Subject: glsl: Fix scoping bug in if statements. X-Git-Tag: 062012170305~10604 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=665d75cc5a23f8024034d0c4176fb281f94a30e9;p=profile%2Fivi%2Fmesa.git glsl: Fix scoping bug in if statements. Fixes glslparsertest/glsl2/scoping-01.frag (successfully compiled but should've failed) and scoping-02.frag (assertion triggered). --- diff --git a/src/glsl/ast_to_hir.cpp b/src/glsl/ast_to_hir.cpp index 6e5d01e..bd1ab78 100644 --- a/src/glsl/ast_to_hir.cpp +++ b/src/glsl/ast_to_hir.cpp @@ -2395,11 +2395,17 @@ ast_selection_statement::hir(exec_list *instructions, ir_if *const stmt = new(ctx) ir_if(condition); - if (then_statement != NULL) + if (then_statement != NULL) { + state->symbols->push_scope(); then_statement->hir(& stmt->then_instructions, state); + state->symbols->pop_scope(); + } - if (else_statement != NULL) + if (else_statement != NULL) { + state->symbols->push_scope(); else_statement->hir(& stmt->else_instructions, state); + state->symbols->pop_scope(); + } instructions->push_tail(stmt);