re PR c++/40373 (ICE with invalid destructor call)
authorJakub Jelinek <jakub@redhat.com>
Mon, 8 Jun 2009 16:48:11 +0000 (18:48 +0200)
committerJakub Jelinek <jakub@gcc.gnu.org>
Mon, 8 Jun 2009 16:48:11 +0000 (18:48 +0200)
PR c++/40373
* call.c (check_dtor_name): Return false even if
get_type_value (name) is error_mark_node.

* g++.dg/template/dtor7.C: New test.

From-SVN: r148282

gcc/cp/ChangeLog
gcc/cp/call.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/template/dtor7.C [new file with mode: 0644]

index 5c0d4730ce6d91c25348b35133c07342730e7e2f..d9327a9d379b9e64ac164c32ecb8055dbf300bad 100644 (file)
@@ -1,5 +1,9 @@
 2009-06-08  Jakub Jelinek  <jakub@redhat.com>
 
+       PR c++/40373
+       * call.c (check_dtor_name): Return false even if
+       get_type_value (name) is error_mark_node.
+
        PR c++/40370
        PR c++/40372
        * parser.c (cp_parser_direct_declarator): Don't set TREE_SIDE_EFFECTS
index 1ab27c738e2e15982bcb5c7b584ad5bd8b596e84..db45ab0a30c7ddad75cea39876623182a5ba8460 100644 (file)
@@ -242,7 +242,7 @@ check_dtor_name (tree basetype, tree name)
       return false;
     }
 
-  if (!name)
+  if (!name || name == error_mark_node)
     return false;
   return same_type_p (TYPE_MAIN_VARIANT (basetype), TYPE_MAIN_VARIANT (name));
 }
index 2a32d8fa4b23da1683b91795edff85de65d545c8..c6e7618254d24fe8a13a705c6362a0b40f35435d 100644 (file)
@@ -4,6 +4,9 @@
        * gcc.dg/builtin-object-size-4.c (test1): Adjust expected results.
        * gcc.dg/builtin-object-size-6.c: New test.
 
+       PR c++/40373
+       * g++.dg/template/dtor7.C: New test.
+
        PR c++/40370
        PR c++/40372
        * g++.dg/template/error41.C: New test.
diff --git a/gcc/testsuite/g++.dg/template/dtor7.C b/gcc/testsuite/g++.dg/template/dtor7.C
new file mode 100644 (file)
index 0000000..0dac69e
--- /dev/null
@@ -0,0 +1,24 @@
+// PR c++/40373
+// { dg-compile }
+
+struct A;      // { dg-bogus "candidates are" "" { xfail *-*-* } }
+namespace
+{
+  struct A;    // { dg-bogus "struct" "" { xfail *-*-* } }
+}
+
+struct B {};
+
+template <typename T> void
+foo (T t)
+{
+  t.~A ();     // { dg-error "does not match destructor name" }
+}
+
+void
+bar ()
+{
+  foo (B ());  // { dg-bogus "instantiated from here" "" { xfail *-*-* } }
+}
+
+// { dg-bogus "is ambiguous" "" { xfail *-*-* } 15 }