about summary refs log tree commit diff
path: root/tests/ui/impl-trait/member-constraints/nested-impl-trait-pass.rs
diff options
context:
space:
mode:
Diffstat (limited to 'tests/ui/impl-trait/member-constraints/nested-impl-trait-pass.rs')
-rw-r--r--tests/ui/impl-trait/member-constraints/nested-impl-trait-pass.rs32
1 files changed, 32 insertions, 0 deletions
diff --git a/tests/ui/impl-trait/member-constraints/nested-impl-trait-pass.rs b/tests/ui/impl-trait/member-constraints/nested-impl-trait-pass.rs
new file mode 100644
index 00000000000..6860fc5e6a5
--- /dev/null
+++ b/tests/ui/impl-trait/member-constraints/nested-impl-trait-pass.rs
@@ -0,0 +1,32 @@
+// Nested impl-traits can impose different member constraints on the same region variable.
+
+//@ check-pass
+// FIXME(-Znext-solver): enable this test
+
+trait Cap<'a> {}
+impl<T> Cap<'_> for T {}
+
+// Assuming the hidden type is `[&'?15 u8; 1]`, we have two distinct member constraints:
+// - '?15 member ['static, 'a, 'b] // from outer impl-trait
+// - '?15 member ['static, 'a]     // from inner impl-trait
+// To satisfy both we can only choose 'a. Concretely, first member constraint requires ?15
+// to outlive at least 'b while the second requires ?15 to outlive 'a. As 'a outlives 'b we
+// end up with 'a as the final member region.
+fn pass_early_bound<'s, 'a, 'b>(a: &'s u8) -> impl IntoIterator<Item = impl Cap<'a>> + Cap<'b>
+where
+    's: 'a,
+    's: 'b,
+{
+    [a]
+}
+
+// Same as the above but with late-bound regions.
+fn pass_late_bound<'s, 'a, 'b>(
+    a: &'s u8,
+    _: &'a &'s u8,
+    _: &'b &'s u8,
+) -> impl IntoIterator<Item = impl Cap<'a>> + Cap<'b> {
+    [a]
+}
+
+fn main() {}