]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
c++: this capture in template [PR125384]
authorJason Merrill <jason@redhat.com>
Thu, 21 May 2026 19:02:21 +0000 (15:02 -0400)
committerJason Merrill <jason@redhat.com>
Thu, 21 May 2026 20:07:22 +0000 (16:07 -0400)
The r16-1019 change to special-case 'this' capture handling dropped the
'const' qualifier from the capture proxy, so the call to rvalue in
finish_this_expr no longer built a NOP_EXPR to express dropping that
'const'.

PR c++/125384
PR c++/113563

gcc/cp/ChangeLog:

* lambda.cc (build_capture_proxy): 'this' capture proxy is const.

gcc/testsuite/ChangeLog:

* g++.dg/cpp0x/lambda/lambda-this23.C: New test.

gcc/cp/lambda.cc
gcc/testsuite/g++.dg/cpp0x/lambda/lambda-this23.C [new file with mode: 0644]

index af0b66afe814ca9830aea959323d21dfc35ffad8..e0d676cae818dfa82717f989f986ba7fd92ca2cc 100644 (file)
@@ -450,7 +450,7 @@ build_capture_proxy (tree member, tree init, bool early_p)
        constness of the closure doesn't matter just like it doesn't matter to
        other by-ref capture.  It's simpler to handle this special case here
        than in lambda_proxy_type.  */
-    type = TREE_TYPE (member);
+    type = cp_build_qualified_type (TREE_TYPE (member), TYPE_QUAL_CONST);
   else
     {
       type = lambda_proxy_type (object);
diff --git a/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-this23.C b/gcc/testsuite/g++.dg/cpp0x/lambda/lambda-this23.C
new file mode 100644 (file)
index 0000000..9317a93
--- /dev/null
@@ -0,0 +1,19 @@
+// PR c++/125384
+// { dg-do compile { target c++11 } }
+
+template <class,class> struct assert_same;
+template <class T> struct assert_same<T,T> {};
+
+template<typename C>
+struct At {
+  void b() {
+    [this](){
+      assert_same <decltype (this), At*> as2;
+    }();
+  }
+};
+
+int main()
+{
+  At<int>{}.b();
+}