From: jason Date: Thu, 29 Jun 2017 21:44:11 +0000 (+0000) Subject: * constexpr.c, error.c, tree.c: Remove WITH_CLEANUP_EXPR handling. X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=31b343e91b190af4b9f27af551031794b357d94e;p=thirdparty%2Fgcc.git * constexpr.c, error.c, tree.c: Remove WITH_CLEANUP_EXPR handling. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@249818 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 5549f720141f..2117eb6f5a1c 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,5 +1,7 @@ 2017-06-29 Jason Merrill + * constexpr.c, error.c, tree.c: Remove WITH_CLEANUP_EXPR handling. + PR c++/81180 - ICE with C++17 deduction of member class template. * pt.c (build_deduction_guide): Correct member template handling. diff --git a/gcc/cp/constexpr.c b/gcc/cp/constexpr.c index 5a5745248664..32180a74c3fd 100644 --- a/gcc/cp/constexpr.c +++ b/gcc/cp/constexpr.c @@ -4519,7 +4519,6 @@ cxx_eval_constant_expression (const constexpr_ctx *ctx, tree t, /* GCC internal stuff. */ case VA_ARG_EXPR: case OBJ_TYPE_REF: - case WITH_CLEANUP_EXPR: case NON_DEPENDENT_EXPR: case BASELINK: case OFFSET_REF: @@ -5533,7 +5532,6 @@ potential_constant_expression_1 (tree t, bool want_rval, bool strict, case BIND_EXPR: return RECUR (BIND_EXPR_BODY (t), want_rval); - case WITH_CLEANUP_EXPR: case CLEANUP_POINT_EXPR: case MUST_NOT_THROW_EXPR: case TRY_CATCH_EXPR: diff --git a/gcc/cp/error.c b/gcc/cp/error.c index 86fa804b317a..43b5cec0a95f 100644 --- a/gcc/cp/error.c +++ b/gcc/cp/error.c @@ -2664,7 +2664,6 @@ dump_expr (cxx_pretty_printer *pp, tree t, int flags) break; case TRY_CATCH_EXPR: - case WITH_CLEANUP_EXPR: case CLEANUP_POINT_EXPR: dump_expr (pp, TREE_OPERAND (t, 0), flags); break; diff --git a/gcc/cp/tree.c b/gcc/cp/tree.c index a52a9e8fa9f1..c037b2c74400 100644 --- a/gcc/cp/tree.c +++ b/gcc/cp/tree.c @@ -90,7 +90,6 @@ lvalue_kind (const_tree ref) case PREINCREMENT_EXPR: case PREDECREMENT_EXPR: case TRY_CATCH_EXPR: - case WITH_CLEANUP_EXPR: case REALPART_EXPR: case IMAGPART_EXPR: return lvalue_kind (TREE_OPERAND (ref, 0)); @@ -3584,11 +3583,6 @@ cp_tree_equal (tree t1, tree t2) return cp_tree_equal (TREE_OPERAND (t1, 1), TREE_OPERAND (t2, 1)); } - case WITH_CLEANUP_EXPR: - if (!cp_tree_equal (TREE_OPERAND (t1, 0), TREE_OPERAND (t2, 0))) - return false; - return cp_tree_equal (TREE_OPERAND (t1, 1), TREE_OPERAND (t1, 1)); - case PARM_DECL: /* For comparing uses of parameters in late-specified return types with an out-of-class definition of the function, but can also come