OSDN Git Service

PR c++/21123
authorjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 30 Nov 2005 20:58:27 +0000 (20:58 +0000)
committerjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 30 Nov 2005 20:58:27 +0000 (20:58 +0000)
        * cp-gimplify.c (cp_genericize_r): Don't dereference invisible reference
        parms in a thunk.

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

gcc/cp/ChangeLog
gcc/cp/cp-gimplify.c
gcc/testsuite/g++.dg/inherit/thunk5.C [new file with mode: 0644]

index 5d2cc80..dcd0d3f 100644 (file)
@@ -1,3 +1,9 @@
+2005-11-30  Jason Merrill  <jason@redhat.com>
+
+       PR c++/21123
+       * cp-gimplify.c (cp_genericize_r): Don't dereference invisible reference 
+       parms in a thunk.
+
 2005-11-30  Ben Elliston  <bje@au.ibm.com>
 
        * typeck.c (build_x_unary_op): Correct spelling in error message.
index a4d59f5..aa71746 100644 (file)
@@ -596,7 +596,10 @@ cp_genericize_r (tree *stmt_p, int *walk_subtrees, void *data)
   tree stmt = *stmt_p;
   struct pointer_set_t *p_set = (struct pointer_set_t*) data;
 
-  if (is_invisiref_parm (stmt))
+  if (is_invisiref_parm (stmt)
+      /* Don't dereference parms in a thunk, pass the references through. */
+      && !(DECL_THUNK_P (current_function_decl)
+           && TREE_CODE (stmt) == PARM_DECL))
     {
       *stmt_p = convert_from_reference (stmt);
       *walk_subtrees = 0;
diff --git a/gcc/testsuite/g++.dg/inherit/thunk5.C b/gcc/testsuite/g++.dg/inherit/thunk5.C
new file mode 100644 (file)
index 0000000..05dba36
--- /dev/null
@@ -0,0 +1,22 @@
+// PR c++/21123
+
+struct A
+{
+  A(const A &a);
+  const A& operator=(const A& a);
+};
+
+struct B
+{
+  virtual A f(A);
+};
+
+struct C : virtual B
+{
+  virtual A f(A);
+};
+
+A C::f(A a) 
+{
+  return a;
+}