From 6bebae75035889a4844eb4d32a695bebf412bcd7 Mon Sep 17 00:00:00 2001 From: Marek Polacek Date: Wed, 10 Jan 2018 17:05:14 +0000 Subject: [PATCH] re PR c++/82541 (Wduplicated-branches triggers in template context) PR c++/82541 * call.c (build_conditional_expr_1): Check complain before warning. * pt.c (tsubst_copy_and_build) : Suppress -Wduplicated-branches. * g++.dg/warn/Wduplicated-branches4.C: New test. From-SVN: r256441 --- gcc/cp/ChangeLog | 7 +++++++ gcc/cp/call.c | 1 + gcc/cp/pt.c | 1 + gcc/testsuite/ChangeLog | 5 +++++ .../g++.dg/warn/Wduplicated-branches4.C | 16 ++++++++++++++++ 5 files changed, 30 insertions(+) create mode 100644 gcc/testsuite/g++.dg/warn/Wduplicated-branches4.C diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 3cce2120b5a..d664bd26af9 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,10 @@ +2018-01-10 Marek Polacek + + PR c++/82541 + * call.c (build_conditional_expr_1): Check complain before warning. + * pt.c (tsubst_copy_and_build) : Suppress + -Wduplicated-branches. + 2018-01-10 Jakub Jelinek PR c++/81327 diff --git a/gcc/cp/call.c b/gcc/cp/call.c index 515e4607de0..87bbf3c7991 100644 --- a/gcc/cp/call.c +++ b/gcc/cp/call.c @@ -5345,6 +5345,7 @@ build_conditional_expr_1 (location_t loc, tree arg1, tree arg2, tree arg3, /* If the ARG2 and ARG3 are the same and don't have side-effects, warn here, because the COND_EXPR will be turned into ARG2. */ if (warn_duplicated_branches + && (complain & tf_warning) && (arg2 == arg3 || operand_equal_p (arg2, arg3, 0))) warning_at (EXPR_LOCATION (result), OPT_Wduplicated_branches, "this condition has identical branches"); diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c index 2fb327a3e28..2deccd822c2 100644 --- a/gcc/cp/pt.c +++ b/gcc/cp/pt.c @@ -17846,6 +17846,7 @@ tsubst_copy_and_build (tree t, exp2 = RECUR (TREE_OPERAND (t, 2)); } + warning_sentinel s(warn_duplicated_branches); RETURN (build_x_conditional_expr (EXPR_LOCATION (t), cond, exp1, exp2, complain)); } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 0bfacf0d0e6..3936188e2f4 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2018-01-10 Marek Polacek + + PR c++/82541 + * g++.dg/warn/Wduplicated-branches4.C: New test. + 2018-01-10 Jakub Jelinek PR c++/81327 diff --git a/gcc/testsuite/g++.dg/warn/Wduplicated-branches4.C b/gcc/testsuite/g++.dg/warn/Wduplicated-branches4.C new file mode 100644 index 00000000000..7963c9e8ab5 --- /dev/null +++ b/gcc/testsuite/g++.dg/warn/Wduplicated-branches4.C @@ -0,0 +1,16 @@ +// PR c++/82541 +// { dg-do compile } +// { dg-options "-Wduplicated-branches" } + +template +struct AR +{ + char a1[N > 0 ? N : 1]; // { dg-bogus "this condition has identical branches" } + char a2[N > 0 ? 1 : 1]; // { dg-warning "this condition has identical branches" } +}; + +int +main () +{ + AR<1> w; +} -- 2.30.2