OSDN Git Service

PR c++/41920
authorjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 20 Jan 2010 21:30:28 +0000 (21:30 +0000)
committerjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 20 Jan 2010 21:30:28 +0000 (21:30 +0000)
* semantics.c (build_lambda_object): Call mark_used on captured
variables.

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

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

index 7269838..828f4b0 100644 (file)
@@ -1,5 +1,9 @@
 2010-01-20  Jason Merrill  <jason@redhat.com>
 
+       PR c++/41920
+       * semantics.c (build_lambda_object): Call mark_used on captured
+       variables.
+
        PR c++/40750
        * decl.c (grokdeclarator): Clear type_quals for a member function
        declared using a typedef.  Don't complain about adding cv-quals
index fa3ecda..1545443 100644 (file)
@@ -5408,6 +5408,9 @@ build_lambda_object (tree lambda_expr)
       tree field = TREE_PURPOSE (node);
       tree val = TREE_VALUE (node);
 
+      if (DECL_P (val))
+       mark_used (val);
+
       /* Mere mortals can't copy arrays with aggregate initialization, so
         do some magic to make it work here.  */
       if (TREE_CODE (TREE_TYPE (field)) == ARRAY_TYPE)
index db9bb35..99c5614 100644 (file)
@@ -1,5 +1,8 @@
 2010-01-20  Jason Merrill  <jason@redhat.com>
 
+       PR c++/41920
+       * g++.dg/cpp0x/lambda/lambda-warn1.C: New.
+
        PR c++/40750
        * g++.dg/parse/fn-typedef1.C: New.
        * g++.dg/other/cv_quals.C: Adjust.
diff --git a/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-warn1.C b/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-warn1.C
new file mode 100644 (file)
index 0000000..b384d5c
--- /dev/null
@@ -0,0 +1,8 @@
+// PR c++/41920
+// { dg-options "-std=c++0x -Wall -Wextra" }
+
+int foo(int i)
+{
+    auto bar = [=](){ return i; };
+    return bar();
+}