re PR c++/43502 ([C++0x] uninitialised read in grokfndecl() with lambda functions...
authorJason Merrill <jason@redhat.com>
Wed, 24 Mar 2010 16:49:06 +0000 (12:49 -0400)
committerJason Merrill <jason@gcc.gnu.org>
Wed, 24 Mar 2010 16:49:06 +0000 (12:49 -0400)
PR c++/43502
* parser.c (make_declarator): Initialize id_loc.
(cp_parser_lambda_declarator_opt): And set it.

From-SVN: r157701

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

index 81df9870121101f2e3e1a641e55431758254d971..0aad33c2ecbb7810c05ea3b4e0be0adc0499089e 100644 (file)
@@ -1,3 +1,9 @@
+2010-03-24  Jason Merrill  <jason@redhat.com>
+
+       PR c++/43502
+       * parser.c (make_declarator): Initialize id_loc.
+       (cp_parser_lambda_declarator_opt): And set it.
+
 2010-03-23  Jason Merrill  <jason@redhat.com>
 
        Make lambda conversion op and op() non-static.
index cbbfd94938d1caa28beeacd87047e93405a4a3c0..41982f77cc9fe03c7a9406c9ca72b50fff7c0113 100644 (file)
@@ -890,6 +890,7 @@ make_declarator (cp_declarator_kind kind)
   declarator->attributes = NULL_TREE;
   declarator->declarator = NULL;
   declarator->parameter_pack_p = false;
+  declarator->id_loc = UNKNOWN_LOCATION;
 
   return declarator;
 }
@@ -7395,6 +7396,7 @@ cp_parser_lambda_declarator_opt (cp_parser* parser, tree lambda_expr)
     declarator = make_call_declarator (declarator, param_list, quals,
                                       exception_spec,
                                        /*late_return_type=*/NULL_TREE);
+    declarator->id_loc = LAMBDA_EXPR_LOCATION (lambda_expr);
 
     fco = grokmethod (&return_type_specs,
                      declarator,
index 692353b6788ce02a5ab8d9f149df58cdebeb810e..d1598dd873d944ae680569d052470bdf5f2b8587 100644 (file)
@@ -1,3 +1,8 @@
+2010-03-24  Jason Merrill  <jason@redhat.com>
+
+       PR c++/43502
+       * g++.dg/cpp0x/lambda/lambda-debug.C: New.
+
 2010-03-24  Martin Jambor  <mjambor@suse.cz>
 
        * gcc.dg/ipa/ipa-1.c: Delete trailing spaces, put the call to f into
diff --git a/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-debug.C b/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-debug.C
new file mode 100644 (file)
index 0000000..07fc189
--- /dev/null
@@ -0,0 +1,15 @@
+// PR c++/43502
+// { dg-options "-std=c++0x -fcompare-debug" }
+
+void g (int n)
+{
+  int bef ([]{return 0;}());
+}
+struct S {
+  void f (int = []{return 0;}(), int = [] { return 0;}());
+};
+int main ()
+{
+  S ().f ();
+  return 0;
+}