re PR c++/37260 (infinite loop in init)
authorPaolo Carlini <paolo.carlini@oracle.com>
Thu, 28 Aug 2008 23:37:41 +0000 (23:37 +0000)
committerPaolo Carlini <paolo@gcc.gnu.org>
Thu, 28 Aug 2008 23:37:41 +0000 (23:37 +0000)
/cp
2008-08-28  Paolo Carlini  <paolo.carlini@oracle.com>

PR c++/37260
* decl.c (reshape_init_r): Check init for error_mark_node.

/testsuite
2008-08-28  Paolo Carlini  <paolo.carlini@oracle.com>

PR c++/37260
* g++.dg/parse/crash44.C: New.

From-SVN: r139740

gcc/cp/ChangeLog
gcc/cp/decl.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/parse/crash44.C [new file with mode: 0644]

index 7d2266c..b462401 100644 (file)
@@ -1,3 +1,8 @@
+2008-08-28  Paolo Carlini  <paolo.carlini@oracle.com>
+
+       PR c++/37260
+       * decl.c (reshape_init_r): Check init for error_mark_node.
+
 2008-08-27  Manuel Lopez-Ibanez  <manu@gcc.gnu.org>
 
        PR c++/17880
index 2f5d6eb..c3d63bb 100644 (file)
@@ -4772,6 +4772,9 @@ reshape_init_r (tree type, reshape_iter *d, bool first_initializer_p)
 {
   tree init = d->cur->value;
 
+  if (error_operand_p (init))
+    return error_mark_node;
+
   /* A non-aggregate type is always initialized with a single
      initializer.  */
   if (!CP_AGGREGATE_TYPE_P (type))
index f65db77..19816c0 100644 (file)
@@ -1,3 +1,8 @@
+2008-08-28  Paolo Carlini  <paolo.carlini@oracle.com>
+
+       PR c++/37260
+       * g++.dg/parse/crash44.C: New.
+
 2008-08-28  Adam Nemet  <anemet@caviumnetworks.com>
 
        * gcc.target/mips/octeon-dmul-1.c: New test.
diff --git a/gcc/testsuite/g++.dg/parse/crash44.C b/gcc/testsuite/g++.dg/parse/crash44.C
new file mode 100644 (file)
index 0000000..abdf827
--- /dev/null
@@ -0,0 +1,15 @@
+// PR c++/37260
+// { dg-options "" }
+
+struct pthread_once_t { };
+struct test {
+  pthread_once_t once;
+};
+
+int main(void) {
+  struct test foo = {
+    once: PTHREAD_ONCE_INITIALIZER // { dg-error "error: 'PTHREAD_ONCE_INITIALIZER' was not declared in this scope" }
+  };
+
+  return 0;
+}