[PR c++/81574] lambda capture of function reference
authorNathan Sidwell <nathan@acm.org>
Wed, 15 Nov 2017 13:18:09 +0000 (13:18 +0000)
committerNathan Sidwell <nathan@gcc.gnu.org>
Wed, 15 Nov 2017 13:18:09 +0000 (13:18 +0000)
https://gcc.gnu.org/ml/gcc-patches/2017-11/msg01200.html
PR c++/81574
* lambda.c (lambda_capture_field_type): Function references are
always catured by reference.

PR c++/81574
* g++.dg/cpp1y/pr81574.C: New.

From-SVN: r254768

gcc/cp/ChangeLog
gcc/cp/lambda.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/cpp1y/pr81574.C [new file with mode: 0644]

index 839042e48c6b29ae6d08e6ee0fbd41e6a21a2379..e8c882f2253984389630fc526c495d390fb1cf80 100644 (file)
@@ -1,3 +1,9 @@
+2017-11-15  Nathan Sidwell  <nathan@acm.org>
+
+       PR c++/81574
+       * lambda.c (lambda_capture_field_type): Function references are
+       always catured by reference.
+
 2017-11-15  Martin Liska  <mliska@suse.cz>
 
        * decl.c (begin_destructor_body): Use cp_build_fold_indirect_ref
index 2cbad878ff651877bbd76a292b7402b5a5df2d0c..4480c67dc5f61814811bf9c79e5be9824340364a 100644 (file)
@@ -245,7 +245,8 @@ lambda_capture_field_type (tree expr, bool explicit_init_p,
     {
       type = non_reference (unlowered_expr_type (expr));
 
-      if (!is_this && by_reference_p)
+      if (!is_this
+         && (by_reference_p || TREE_CODE (type) == FUNCTION_TYPE))
        type = build_reference_type (type);
     }
 
index 1dada439fafe2b9c46a1bffb6345cb43c387f290..8478a7a88f2d5ac60805dbfc18fc9bc089c65ae4 100644 (file)
@@ -1,3 +1,8 @@
+2017-11-15  Nathan Sidwell  <nathan@acm.org>
+
+       PR c++/81574
+       * g++.dg/cpp1y/pr81574.C: New.
+
 2017-11-15  Richard Biener  <rguenther@suse.de>
 
        PR tree-optimization/82985
diff --git a/gcc/testsuite/g++.dg/cpp1y/pr81574.C b/gcc/testsuite/g++.dg/cpp1y/pr81574.C
new file mode 100644 (file)
index 0000000..f9949ab
--- /dev/null
@@ -0,0 +1,13 @@
+// { dg-do compile { target c++14 } }
+// PR c++/81574 references to functions are captured by reference.
+
+// 8.1.5.2/10
+// For each entity captured by copy, ... an lvalue reference to the
+// referenced function type if the entity is a reference to a function
+
+void f (void (&b)())
+{
+  [=] {  b; } ();
+  [=, b(f)] { b; } ();
+  [=, b(b)] { b; } ();
+}