OSDN Git Service

* parser.c (cp_parser_type_id_1): 'auto' type is ok with a
authorjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 9 Jun 2009 04:18:54 +0000 (04:18 +0000)
committerjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>
Tue, 9 Jun 2009 04:18:54 +0000 (04:18 +0000)
late-specified return type.

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

gcc/cp/ChangeLog
gcc/cp/parser.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/cpp0x/auto15.C [new file with mode: 0644]

index d9327a9..c4e84aa 100644 (file)
@@ -1,3 +1,8 @@
+2009-06-08  Jason Merrill  <jason@redhat.com>
+
+       * parser.c (cp_parser_type_id_1): 'auto' type is ok with a
+       late-specified return type.
+
 2009-06-08  Jakub Jelinek  <jakub@redhat.com>
 
        PR c++/40373
index 05ae257..b988850 100644 (file)
@@ -13848,8 +13848,17 @@ cp_parser_type_id_1 (cp_parser* parser, bool is_template_arg)
   if (type_specifier_seq.type
       && type_uses_auto (type_specifier_seq.type))
     {
-      error ("invalid use of %<auto%>");
-      return error_mark_node;
+      /* A type-id with type 'auto' is only ok if the abstract declarator
+        is a function declarator with a late-specified return type.  */
+      if (abstract_declarator
+         && abstract_declarator->kind == cdk_function
+         && abstract_declarator->u.function.late_return_type)
+       /* OK */;
+      else
+       {
+         error ("invalid use of %<auto%>");
+         return error_mark_node;
+       }
     }
   
   return groktypename (&type_specifier_seq, abstract_declarator,
index e20679a..b08a0b9 100644 (file)
@@ -1,3 +1,7 @@
+2009-06-08  Jason Merrill  <jason@redhat.com>
+
+       * g++.dg/cpp0x/auto15.C: New.
+
 2009-06-08  Jan Hubicka  <jh@suse.cz>
 
        PR debug/39834
diff --git a/gcc/testsuite/g++.dg/cpp0x/auto15.C b/gcc/testsuite/g++.dg/cpp0x/auto15.C
new file mode 100644 (file)
index 0000000..b23e1e2
--- /dev/null
@@ -0,0 +1,13 @@
+// { dg-options "-std=c++0x" }
+
+template< typename Fn > struct function;
+
+template< typename Result, typename ... ArgTypes >
+struct function< auto (ArgTypes...)->Result > {
+};
+
+int main()
+{
+   function< auto(double)->int > y;
+   return 0;
+}