From 9e851845f6bcd7c13f3d42c13cd2f1c0e87f68cc Mon Sep 17 00:00:00 2001 From: Jakub Jelinek Date: Tue, 28 Nov 2017 09:43:32 +0100 Subject: tree.def (SWITCH_EXPR): Change from 3 operand to 2 operand tree. * tree.def (SWITCH_EXPR): Change from 3 operand to 2 operand tree. Adjust comment. * tree.h (SWITCH_LABELS): Remove. * gimplify.c (gimplify_switch_expr): Don't test SWITCH_LABELS, assert SWITCH_BODY is non-NULL. * tree-pretty-print.c (dump_generic_node): Remove SWITCH_LABELS handling. * tree.c (block_may_fallthru): Always return true; for SWITCH_EXPR. c/ * c-typeck.c (c_start_case): Build SWITCH_EXPR using build2 instead of build3. cp/ * cp-gimplify.c (genericize_switch_stmt): Build SWITCH_EXPR using build2_loc instead of build3_loc. ada/ * gcc-interface/trans.c (Case_Statement_to_gnu): Build SWITCH_EXPR using build2 instead of build3. jit/ * jit-playback.c (add_switch): Build SWITCH_EXPR using build2 instead of build3. Formatting fixes. Adjust funciton comment. fortran/ * trans-decl.c (gfc_trans_entry_master_switch): Build SWITCH_EXPR using fold_build2_loc instead of fold_build3_loc. * trans-io.c (io_result): Likewise. * trans-stmt.c (gfc_trans_integer_select, gfc_trans_character_select): Likewise. go/ * go-gcc.cc (Gcc_backend::switch_statement): Build SWITCH_EXPR using build2_loc instead of build3_loc. brig/ * brigfrontend/brig-branch-inst-handler.cc (brig_branch_inst_handler::operator): Build SWITCH_EXPR using build2 instead of build3. From-SVN: r255192 --- gcc/brig/ChangeLog | 6 ++++++ gcc/brig/brigfrontend/brig-branch-inst-handler.cc | 4 ++-- 2 files changed, 8 insertions(+), 2 deletions(-) (limited to 'gcc/brig') diff --git a/gcc/brig/ChangeLog b/gcc/brig/ChangeLog index ba07ca39e36..3e8f44330da 100644 --- a/gcc/brig/ChangeLog +++ b/gcc/brig/ChangeLog @@ -1,3 +1,9 @@ +2017-11-28 Jakub Jelinek + + * brigfrontend/brig-branch-inst-handler.cc + (brig_branch_inst_handler::operator): Build SWITCH_EXPR using build2 + instead of build3. + 2017-11-17 Henry Linjamäki * brigfrontend/brig-util.cc: Fix sprintf format string type mismatch diff --git a/gcc/brig/brigfrontend/brig-branch-inst-handler.cc b/gcc/brig/brigfrontend/brig-branch-inst-handler.cc index 039f1853d4a..a660698c8a3 100644 --- a/gcc/brig/brigfrontend/brig-branch-inst-handler.cc +++ b/gcc/brig/brigfrontend/brig-branch-inst-handler.cc @@ -167,8 +167,8 @@ brig_branch_inst_handler::operator () (const BrigBase *base) tree select = operands[0]; tree cases = operands[1]; - tree switch_expr = build3 (SWITCH_EXPR, TREE_TYPE (select), select, - NULL_TREE, NULL_TREE); + tree switch_expr = build2 (SWITCH_EXPR, TREE_TYPE (select), select, + NULL_TREE); tree default_case = build_case_label (NULL_TREE, NULL_TREE, -- cgit v1.2.1