* except.c (expand_throw): Make sure first argument to
authormmitchel <mmitchel@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 13 Nov 1998 13:02:24 +0000 (13:02 +0000)
committermmitchel <mmitchel@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 13 Nov 1998 13:02:24 +0000 (13:02 +0000)
__cp_push_exception is of type `void*' to avoid spurious error
messages.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@23639 138bc75d-0d04-0410-961f-82ee72b054a4

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

index 475ada1..c613d80 100644 (file)
@@ -1,3 +1,9 @@
+1998-11-13  Mark Mitchell  <mark@markmitchell.com>
+
+       * except.c (expand_throw): Make sure first argument to
+       __cp_push_exception is of type `void*' to avoid spurious error
+       messages.
+
 1998-11-11  Jason Merrill  <jason@yorick.cygnus.com>
 
        * pt.c (try_one_overload): Take orig_targs again.  Only check for
index 2d069da..d2cc3e4 100644 (file)
@@ -998,10 +998,7 @@ expand_throw (exp)
        }
 
       if (TREE_CODE (TREE_TYPE (exp)) == POINTER_TYPE)
-       {
-         throw_type = build_eh_type (exp);
-         exp = build_reinterpret_cast (ptr_type_node, exp);
-       }
+       throw_type = build_eh_type (exp);
       else
        {
          tree object, ptr;
@@ -1075,6 +1072,10 @@ expand_throw (exp)
          exp = ptr;
        }
 
+      /* Cast EXP to `void *' so that it will match the prototype for
+        __cp_push_exception.  */
+      exp = build_reinterpret_cast (ptr_type_node, exp);
+
       if (cleanup == NULL_TREE)
        {
          cleanup = build_int_2 (0, 0);
diff --git a/gcc/testsuite/g++.old-deja/g++.eh/throw1.C b/gcc/testsuite/g++.old-deja/g++.eh/throw1.C
new file mode 100644 (file)
index 0000000..49a7d1e
--- /dev/null
@@ -0,0 +1,12 @@
+// Build don't link:
+
+void athrow(const int & e) throw(int)
+{
+   throw e;
+}
+
+int main(void)
+{
+   athrow(int());
+   return 0;
+}