From: Nathan Sidwell Date: Fri, 5 Aug 2016 19:58:36 +0000 (+0000) Subject: re PR c++/68724 (ice in unify, at cp/pt.c:19902) X-Git-Tag: releases/gcc-5.5.0~923 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=cace1462160bc49a805b51c757b1a434abc509dc;p=thirdparty%2Fgcc.git re PR c++/68724 (ice in unify, at cp/pt.c:19902) PR c++/68724 * pt.c (unify): TRAIT_EXPR is an expr. PR c++/68724 * g++.dg/cpp0x/pr68724.C: New. From-SVN: r239177 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 57aeb7aab27b..86ba33098743 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,8 @@ +2016-08-05 Nathan Sidwell + + PR c++/68724 + * pt.c (unify): TRAIT_EXPR is an expr. + 2016-07-25 Jason Merrill PR c++/71833 diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c index 29badc142c6c..578fa20184bd 100644 --- a/gcc/cp/pt.c +++ b/gcc/cp/pt.c @@ -18807,7 +18807,7 @@ unify (tree tparms, tree targs, tree parm, tree arg, int strict, /* An unresolved overload is a nondeduced context. */ if (is_overloaded_fn (parm) || type_unknown_p (parm)) return unify_success (explain_p); - gcc_assert (EXPR_P (parm)); + gcc_assert (EXPR_P (parm) || TREE_CODE (parm) == TRAIT_EXPR); /* We must be looking at an expression. This can happen with something like: diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 20670c4377c0..d78dded2ad65 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2016-08-05 Nathan Sidwell + + PR c++/68724 + * g++.dg/cpp0x/pr68724.C: New. + 2016-07-29 Paul Thomas Backport from trunk: diff --git a/gcc/testsuite/g++.dg/cpp0x/pr68724.C b/gcc/testsuite/g++.dg/cpp0x/pr68724.C new file mode 100644 index 000000000000..ff6d84dc3f7b --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp0x/pr68724.C @@ -0,0 +1,15 @@ +// PR 68724 ICE in unificiation +// { dg-do compile { target c++11 } } + +template +struct integral_constant +{ +}; + +integral_constant inst; + +template +struct integral_constant // { dg-error "" } +{ +}; +