]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
re PR c++/21123 (ICE in cp_expr_size, at cp/cp-objcp-common.c:101)
authorJason Merrill <jason@redhat.com>
Wed, 30 Nov 2005 20:58:27 +0000 (15:58 -0500)
committerJason Merrill <jason@gcc.gnu.org>
Wed, 30 Nov 2005 20:58:27 +0000 (15:58 -0500)
        PR c++/21123
        * cp-gimplify.c (cp_genericize_r): Don't dereference invisible reference
        parms in a thunk.

From-SVN: r107738

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

index 5d2cc80c0853d1989059f05218b7c3bc22b152d4..dcd0d3fe8bc7949b52a83743b991d69102dacfa9 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 a4d59f563fc8b995978bdaccf6f6d1b9d17d7522..aa7174688de0312d4e37af3feea2ad52d8e173a1 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;
+}