+2019-11-27 Andrew Sutton <asutton@lock3software.com>
+
+ PR c++/88395
+ * constraint.cc (satisfy_declaration_constraints): Push tinst levels
+ around satisfaction.
+
2019-11-27 Andrew Sutton <asutton@lock3software.com>
Diagnose certain constraint errors as hard errors, but otherwise treat
tree result = boolean_true_node;
if (norm)
{
+ push_tinst_level (t);
push_access_scope (t);
result = satisfy_associated_constraints (norm, args, info);
pop_access_scope (t);
+ pop_tinst_level ();
}
if (info.quiet ())
+2019-11-18 Andrew Sutton <asutton@lock3software.com>
+
+ PR c++/88395
+ * g++.dg/cpp2a/concepts-pr88395.C: New.
+ * g++.dg/cpp2a/concepts-recursive-sat1.C: New.
+ * g++.dg/cpp2a/concepts-recursive-sat2.C: New.
+ * g++.dg/cpp2a/concepts-recursive-sat3.C: New.
+
2019-11-27 Vladimir Makarov <vmakarov@redhat.com>
PR rtl-optimization/90007
--- /dev/null
+// { dg-do compile { target c++2a } }
+
+template <class T, class U>
+concept Concept2 = requires (T t, U u)
+{
+ t += u; // { dg-error "template instantiation depth" }
+};
+
+template <class T>
+concept Concept = Concept2 <T, T>;
+
+struct S
+{
+ template <Concept T>
+ constexpr S& operator += (T o);
+};
+
+constexpr S operator * (S a, S b)
+{
+ return a += b;
+}
+
+// { dg-prune-output "compilation terminated" }
--- /dev/null
+// { dg-do compile { target c++2a } }
+
+template<int N, typename T>
+concept Foo = requires(T t) { foo<N + 1>(t); }; // { dg-error "template instantiation depth" }
+
+template<int N = 1, typename T = int>
+ requires Foo<N, T>
+int foo(T t)
+{
+ return foo<N + 1>(t);
+}
+
+int main(int, char**)
+{
+ return foo<1>(1);
+}
+
+// { dg-prune-output "compilation terminated" }
--- /dev/null
+// { dg-do compile { target c++2a } }
+
+template<typename T>
+concept Fooable = requires(T t) { foo(t); }; // { dg-error "template instantiation depth" }
+
+template<Fooable T>
+void foo(T t) { }
+
+void test()
+{
+ struct S {} s;
+ foo(s);
+}
+
+// { dg-prune-output "compilation terminated" }
--- /dev/null
+// { dg-do compile { target c++2a } }
+
+template<typename T>
+concept Fooable = requires(T t) { foo(t); };
+
+template<Fooable T>
+void foo(T t) { }
+
+void test()
+{
+ foo(0); // { dg-error "unsatisfied constraints" }
+}