Commit d6c057ab by Jason Merrill Committed by Jason Merrill

re PR c++/42013 (cv-qualification of conditional expression type depending on…

re PR c++/42013 (cv-qualification of conditional expression type depending on the value of its first expression?!?)

	PR c++/42013
	* call.c (build_conditional_expr): Check specifically for folding
	to CALL_EXPR rather than TREE_SIDE_EFFECTS.

From-SVN: r154129
parent c8f59bc8
2009-11-12 Jason Merrill <jason@redhat.com> 2009-11-12 Jason Merrill <jason@redhat.com>
PR c++/42013
* call.c (build_conditional_expr): Check specifically for folding
to CALL_EXPR rather than TREE_SIDE_EFFECTS.
2009-11-12 Jason Merrill <jason@redhat.com>
* typeck.c (cv_qualified_p): New fn. * typeck.c (cv_qualified_p): New fn.
(decay_conversion): Use it. (decay_conversion): Use it.
* cp-tree.h: Declare it. * cp-tree.h: Declare it.
......
...@@ -3605,6 +3605,7 @@ build_conditional_expr (tree arg1, tree arg2, tree arg3, ...@@ -3605,6 +3605,7 @@ build_conditional_expr (tree arg1, tree arg2, tree arg3,
tree arg2_type; tree arg2_type;
tree arg3_type; tree arg3_type;
tree result = NULL_TREE; tree result = NULL_TREE;
tree result_save;
tree result_type = NULL_TREE; tree result_type = NULL_TREE;
bool lvalue_p = true; bool lvalue_p = true;
struct z_candidate *candidates = 0; struct z_candidate *candidates = 0;
...@@ -3991,12 +3992,12 @@ build_conditional_expr (tree arg1, tree arg2, tree arg3, ...@@ -3991,12 +3992,12 @@ build_conditional_expr (tree arg1, tree arg2, tree arg3,
} }
valid_operands: valid_operands:
result = build3 (COND_EXPR, result_type, arg1, arg2, arg3); result_save = build3 (COND_EXPR, result_type, arg1, arg2, arg3);
result = fold_if_not_in_template (result_save);
if (cp_unevaluated_operand && TREE_SIDE_EFFECTS (result)) if (cp_unevaluated_operand && TREE_CODE (result) == CALL_EXPR)
/* Avoid folding a ?: of two calls within decltype (c++/42013). */; /* Avoid folding to a CALL_EXPR within decltype (c++/42013). */
else result = result_save;
result = fold_if_not_in_template (result);
/* We can't use result_type below, as fold might have returned a /* We can't use result_type below, as fold might have returned a
throw_expr. */ throw_expr. */
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
template<typename _Tp> template<typename _Tp>
_Tp _Tp
declval(); __attribute ((const)) declval();
template<typename _Tp, typename _Up> template<typename _Tp, typename _Up>
struct common_type struct common_type
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment