except.c (initialize_handler_parm): Expect __cxa_begin_catch to return pointers to...
authorRichard Sandiford <rsandifo@redhat.com>
Tue, 19 Jun 2001 13:32:57 +0000 (13:32 +0000)
committerJason Merrill <jason@gcc.gnu.org>
Tue, 19 Jun 2001 13:32:57 +0000 (09:32 -0400)
        * except.c (initialize_handler_parm): Expect __cxa_begin_catch to
        return pointers to data members by reference rather than by value.

From-SVN: r43456

gcc/cp/ChangeLog
gcc/cp/except.c
gcc/testsuite/g++.old-deja/g++.eh/ptrmem1.C [new file with mode: 0644]

index 99643259c5115e526ea0082a0d5c842de6c43416..ea5de138d545c0ae7fde0126c949a8dfc41a14fb 100644 (file)
@@ -1,3 +1,8 @@
+2001-06-19  Richard Sandiford  <rsandifo@redhat.com>
+
+       * except.c (initialize_handler_parm): Expect __cxa_begin_catch to
+       return pointers to data members by reference rather than by value.
+
 2001-06-18  Jason Merrill  <jason_merrill@redhat.com>
 
        Implement the Named Return Value optimization.
index 458590a8f57251fdc5fd0dae6c962ff3e3140b14..46ffd6e5b760a74dd95987185192ce2df3caa0f6 100644 (file)
@@ -348,7 +348,7 @@ initialize_handler_parm (decl, exp)
      adjusted by value from __cxa_begin_catch.  Others are returned by 
      reference.  */
   init_type = TREE_TYPE (decl);
-  if (TREE_CODE (init_type) != POINTER_TYPE
+  if (! TYPE_PTR_P (init_type)
       && TREE_CODE (init_type) != REFERENCE_TYPE)
     init_type = build_reference_type (init_type);
 
@@ -357,8 +357,8 @@ initialize_handler_parm (decl, exp)
 
   /* Since pointers are passed by value, initialize a reference to
      pointer catch parm with the address of the temporary.  */
-  if (TREE_CODE (init_type) == REFERENCE_TYPE 
-      && TREE_CODE (TREE_TYPE (init_type)) == POINTER_TYPE)
+  if (TREE_CODE (init_type) == REFERENCE_TYPE
+      && TYPE_PTR_P (TREE_TYPE (init_type)))
     exp = build_unary_op (ADDR_EXPR, exp, 1);
 
   exp = ocp_convert (init_type, exp, CONV_IMPLICIT|CONV_FORCE_TEMP, 0);
diff --git a/gcc/testsuite/g++.old-deja/g++.eh/ptrmem1.C b/gcc/testsuite/g++.old-deja/g++.eh/ptrmem1.C
new file mode 100644 (file)
index 0000000..ba70612
--- /dev/null
@@ -0,0 +1,15 @@
+extern "C" void exit (int);
+extern "C" void abort (void);
+struct A { int i; };
+int main ()
+{
+  try { throw &A::i; }
+  catch (int A::*p)
+    {
+      if (p == &A::i)
+       exit (0);
+      else
+       abort ();
+    }
+  abort ();
+}