PR c++/82565 - ICE with concepts and generic lambda.
authorJason Merrill <jason@redhat.com>
Tue, 13 Mar 2018 20:22:31 +0000 (16:22 -0400)
committerJason Merrill <jason@gcc.gnu.org>
Tue, 13 Mar 2018 20:22:31 +0000 (16:22 -0400)
* pt.c (instantiate_decl): Clear fn_context for lambdas.

From-SVN: r258502

gcc/cp/ChangeLog
gcc/cp/pt.c
gcc/testsuite/g++.dg/concepts/lambda1.C [new file with mode: 0644]

index 23079f0592318c0651999abb5f981ea84d7160ab..da81495e8a4ecc61f72ed7707361c67679ae0f96 100644 (file)
@@ -1,3 +1,8 @@
+2018-03-13  Jason Merrill  <jason@redhat.com>
+
+       PR c++/82565 - ICE with concepts and generic lambda.
+       * pt.c (instantiate_decl): Clear fn_context for lambdas.
+
 2018-03-13  Jason Merrill  <jason@redhat.com>
 
        PR c++/84720 - ICE with rvalue ref non-type argument.
index a16aef6bf58eede877681a340f18f1202dec8a37..d720c33cf0af8b37277ec7ba75f188b2767c1b05 100644 (file)
@@ -23460,6 +23460,9 @@ instantiate_decl (tree d, bool defer_ok, bool expl_inst_class_mem_p)
   bool push_to_top, nested;
   tree fn_context;
   fn_context = decl_function_context (d);
+  if (LAMBDA_FUNCTION_P (d))
+    /* tsubst_lambda_expr resolved any references to enclosing functions.  */
+    fn_context = NULL_TREE;
   nested = current_function_decl != NULL_TREE;
   push_to_top = !(nested && fn_context == current_function_decl);
 
diff --git a/gcc/testsuite/g++.dg/concepts/lambda1.C b/gcc/testsuite/g++.dg/concepts/lambda1.C
new file mode 100644 (file)
index 0000000..a77e654
--- /dev/null
@@ -0,0 +1,32 @@
+// PR c++/82565
+// { dg-do compile { target c++14 } }
+// { dg-additional-options -fconcepts }
+
+struct string
+{
+  string();
+  string(const char *);
+  bool empty() const;
+};
+
+template<typename T, typename ReturnType>
+concept bool Concept() {
+  return requires(T t, const string& s) {
+    { t(s) } -> ReturnType;
+  };
+}
+
+struct test {
+  string _str;
+
+  template<typename Visitor>
+    requires Concept<Visitor, bool>()
+  decltype(auto) visit(Visitor&& visitor) const {
+    return visitor(_str);
+  }
+
+};
+
+int main() {
+  test().visit([] (auto& x) { return x.empty(); });
+}