]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
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 7d2266c65eb04b6ef7665515152b1637566d1ef5..b462401c6546b409d96e29827723bcbb516c65b0 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 2f5d6ebd13ff0b4cc2baf37c3cc2046d008e3d2e..c3d63bbeaadf2a15fda4f8fd5e94d7111f06b468 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 f65db77f24bac0805b8db665bcc6709457054e1b..19816c0bf4a9f18632aa22c40ba55919526c7d9a 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;
+}