re PR c++/56177 (ICE when used forward for 'auto f();')
authorJason Merrill <jason@redhat.com>
Wed, 6 Feb 2013 03:33:55 +0000 (22:33 -0500)
committerJason Merrill <jason@gcc.gnu.org>
Wed, 6 Feb 2013 03:33:55 +0000 (22:33 -0500)
PR c++/56177
* decl.c (start_preparsed_function): Update restype if we change
decl1.

From-SVN: r195780

gcc/cp/ChangeLog
gcc/cp/decl.c
gcc/testsuite/g++.dg/cpp1y/auto-fn14.C [new file with mode: 0644]

index ce0bfad..a2bd701 100644 (file)
@@ -1,5 +1,9 @@
 2013-02-05  Jason Merrill  <jason@redhat.com>
 
+       PR c++/56177
+       * decl.c (start_preparsed_function): Update restype if we change
+       decl1.
+
        PR c++/56208
        * pt.c (fn_type_unification): Discard any access checks from
        substituting explicit args.
index 9b40018..cfee0f8 100644 (file)
@@ -13116,6 +13116,7 @@ start_preparsed_function (tree decl1, tree attrs, int flags)
            DECL_CONTEXT (decl1) = DECL_CONTEXT (DECL_TI_TEMPLATE (decl1));
        }
       fntype = TREE_TYPE (decl1);
+      restype = TREE_TYPE (fntype);
 
       /* If #pragma weak applies, mark the decl appropriately now.
         The pragma only applies to global functions.  Because
diff --git a/gcc/testsuite/g++.dg/cpp1y/auto-fn14.C b/gcc/testsuite/g++.dg/cpp1y/auto-fn14.C
new file mode 100644 (file)
index 0000000..e7e8699
--- /dev/null
@@ -0,0 +1,5 @@
+// PR c++/56177
+// { dg-options "-std=c++1y" }
+
+auto f ();
+auto f () { return 33; }