aboutsummaryrefslogtreecommitdiff
path: root/gcc/cp/cvt.c
diff options
context:
space:
mode:
authorJason Merrill <jason@redhat.com>2018-04-27 11:00:53 -0400
committerJason Merrill <jason@gcc.gnu.org>2018-04-27 11:00:53 -0400
commit6d0e87b25ee21493d4f47bb39aee3e2d33cb08d9 (patch)
treedf50d3a40a9ba75887fd0d79d59d06b3940f8dc9 /gcc/cp/cvt.c
parent4bdc2738ce61b5f380930f670709ed9e9cd7cf2a (diff)
downloadgcc-6d0e87b25ee21493d4f47bb39aee3e2d33cb08d9.zip
gcc-6d0e87b25ee21493d4f47bb39aee3e2d33cb08d9.tar.gz
gcc-6d0e87b25ee21493d4f47bb39aee3e2d33cb08d9.tar.bz2
PR c++/85545 - ICE with noexcept PMF conversion.
* cvt.c (cp_fold_convert): Pass PMF CONSTRUCTORs to build_ptrmemfunc. * typeck.c (build_ptrmemfunc): Don't build a NOP_EXPR for zero adjustment. (build_ptrmemfunc_access_expr): Special-case CONSTRUCTORs. From-SVN: r259712
Diffstat (limited to 'gcc/cp/cvt.c')
-rw-r--r--gcc/cp/cvt.c8
1 files changed, 5 insertions, 3 deletions
diff --git a/gcc/cp/cvt.c b/gcc/cp/cvt.c
index a3735a1..0f045e2 100644
--- a/gcc/cp/cvt.c
+++ b/gcc/cp/cvt.c
@@ -601,14 +601,16 @@ cp_fold_convert (tree type, tree expr)
tree conv;
if (TREE_TYPE (expr) == type)
conv = expr;
- else if (TREE_CODE (expr) == PTRMEM_CST
- || (TREE_CODE (expr) == CONSTRUCTOR
- && TYPE_PTRMEMFUNC_P (type)))
+ else if (TREE_CODE (expr) == PTRMEM_CST)
{
/* Avoid wrapping a PTRMEM_CST in NOP_EXPR. */
conv = copy_node (expr);
TREE_TYPE (conv) = type;
}
+ else if (TREE_CODE (expr) == CONSTRUCTOR
+ && TYPE_PTRMEMFUNC_P (type))
+ conv = build_ptrmemfunc (TYPE_PTRMEMFUNC_FN_TYPE (type), expr,
+ true, false, tf_warning_or_error);
else
{
conv = fold_convert (type, expr);