about summary refs log tree commit diff
path: root/src/test
diff options
context:
space:
mode:
authorMatthew Jasper <mjjasper1@gmail.com>2020-08-14 21:51:28 +0100
committerMatthew Jasper <mjjasper1@gmail.com>2020-10-06 11:19:32 +0100
commite674cf0200347c5e58f8a3867657187b12e7b496 (patch)
tree6e5cf10ce84c56e13349cc2024b82eebcc1f87eb /src/test
parentd08ab945de8ede93366c6ffc12ed58068a73b4a0 (diff)
downloadrust-e674cf0200347c5e58f8a3867657187b12e7b496.tar.gz
rust-e674cf0200347c5e58f8a3867657187b12e7b496.zip
Normalize super trait bounds when confirming object candidates
Diffstat (limited to 'src/test')
-rw-r--r--src/test/ui/associated-types/object-normalization.rs26
1 files changed, 26 insertions, 0 deletions
diff --git a/src/test/ui/associated-types/object-normalization.rs b/src/test/ui/associated-types/object-normalization.rs
new file mode 100644
index 00000000000..1f93248e10e
--- /dev/null
+++ b/src/test/ui/associated-types/object-normalization.rs
@@ -0,0 +1,26 @@
+// ignore-tidy-linelength
+
+// Check that we normalize super predicates for object candidates.
+
+// check-pass
+
+use std::ops::Index;
+
+fn next<'a, T>(s: &'a mut dyn SVec<Item = T, Output = T>) {
+    // To prove
+    // `dyn SVec<Item = T, Output = T>: SVec`
+    // we need to show
+    // `dyn SVec<Item = T, Output = T> as Index>::Output == <dyn SVec<Item = T, Output = T> as SVec>::Item`
+    // which, with the current normalization strategy, has to be eagerly
+    // normalized to:
+    // `dyn SVec<Item = T, Output = T> as Index>::Output == T`.
+    let _ = s.len();
+}
+
+trait SVec: Index<usize, Output = <Self as SVec>::Item> {
+    type Item;
+
+    fn len(&self) -> usize;
+}
+
+fn main() {}