re PR c++/58665 (ICE with using incomplete struct)
authorPaolo Carlini <paolo.carlini@oracle.com>
Tue, 8 Oct 2013 21:54:06 +0000 (21:54 +0000)
committerPaolo Carlini <paolo@gcc.gnu.org>
Tue, 8 Oct 2013 21:54:06 +0000 (21:54 +0000)
/cp
2013-10-08  Paolo Carlini  <paolo.carlini@oracle.com>

PR c++/58665
Revert:
2013-10-04  Paolo Carlini  <paolo.carlini@oracle.com>

PR c++/58448
* pt.c (tsubst): Use error_operand_p on parameter t.

/testsuite
2013-10-08  Paolo Carlini  <paolo.carlini@oracle.com>

PR c++/58665
Revert:
2013-10-04  Paolo Carlini  <paolo.carlini@oracle.com>

PR c++/58448
* g++.dg/template/crash117.C: New.

From-SVN: r203288

gcc/cp/ChangeLog
gcc/cp/pt.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/template/crash117.C [deleted file]

index fc2ec31..3e68712 100644 (file)
@@ -1,3 +1,12 @@
+2013-10-08  Paolo Carlini  <paolo.carlini@oracle.com>
+
+       PR c++/58665
+       Revert:
+       2013-10-04  Paolo Carlini  <paolo.carlini@oracle.com>
+
+       PR c++/58448
+       * pt.c (tsubst): Use error_operand_p on parameter t.
+
 2013-10-06  Paolo Carlini  <paolo.carlini@oracle.com>
 
        PR c++/58126
index 2828cc9..a350007 100644 (file)
@@ -11272,7 +11272,7 @@ tsubst (tree t, tree args, tsubst_flags_t complain, tree in_decl)
   enum tree_code code;
   tree type, r = NULL_TREE;
 
-  if (t == NULL_TREE
+  if (t == NULL_TREE || t == error_mark_node
       || t == integer_type_node
       || t == void_type_node
       || t == char_type_node
@@ -11281,9 +11281,6 @@ tsubst (tree t, tree args, tsubst_flags_t complain, tree in_decl)
       || TREE_CODE (t) == TRANSLATION_UNIT_DECL)
     return t;
 
-  if (error_operand_p (t))
-    return error_mark_node;
-
   if (DECL_P (t))
     return tsubst_decl (t, args, complain);
 
index 68aac9c..a45b913 100644 (file)
@@ -1,3 +1,12 @@
+2013-10-08  Paolo Carlini  <paolo.carlini@oracle.com>
+
+       PR c++/58665
+       Revert:
+       2013-10-04  Paolo Carlini  <paolo.carlini@oracle.com>
+
+       PR c++/58448
+       * g++.dg/template/crash117.C: New.
+
 2013-10-08  Andreas Krebbel  <Andreas.Krebbel@de.ibm.com>
 
        * gcc.target/s390/htm-nofloat-2.c: Add -mzarch to asm options.
diff --git a/gcc/testsuite/g++.dg/template/crash117.C b/gcc/testsuite/g++.dg/template/crash117.C
deleted file mode 100644 (file)
index 813140e..0000000
+++ /dev/null
@@ -1,6 +0,0 @@
-// PR c++/58448
-
-class SmallVector; struct Types4;
-template <typename, typename, typename, typename> struct Types {
-  typedef Types4<>::Constructable // { dg-error "template|typedef|expected" }
-} Types<SmallVector, SmallVector, SmallVector, SmallVector>:: > // { dg-error "expected" }