]> git.lizzy.rs Git - rust.git/commitdiff
Add a test showing that we don't infer across multiple uses of the same opaque type...
authorOli Scherer <git-spam-no-reply9815368754983@oli-obk.de>
Mon, 7 Feb 2022 16:04:23 +0000 (16:04 +0000)
committerOli Scherer <git-spam-no-reply9815368754983@oli-obk.de>
Mon, 7 Feb 2022 16:04:23 +0000 (16:04 +0000)
src/test/ui/type-alias-impl-trait/multiple-def-uses-in-one-fn-infer.rs [new file with mode: 0644]
src/test/ui/type-alias-impl-trait/multiple-def-uses-in-one-fn-infer.stderr [new file with mode: 0644]

diff --git a/src/test/ui/type-alias-impl-trait/multiple-def-uses-in-one-fn-infer.rs b/src/test/ui/type-alias-impl-trait/multiple-def-uses-in-one-fn-infer.rs
new file mode 100644 (file)
index 0000000..08cb48c
--- /dev/null
@@ -0,0 +1,13 @@
+// https://github.com/rust-lang/rust/issues/73481
+// This test used to cause unsoundness, since one of the two possible
+// resolutions was chosen at random instead of erroring due to conflicts.
+
+#![feature(type_alias_impl_trait)]
+
+type Y<A, B> = impl std::fmt::Debug;
+
+fn g<A, B>() -> (Y<A, B>, Y<B, A>) {
+    (42_i64, 60) //~^ ERROR concrete type differs from previous defining opaque type use
+}
+
+fn main() {}
diff --git a/src/test/ui/type-alias-impl-trait/multiple-def-uses-in-one-fn-infer.stderr b/src/test/ui/type-alias-impl-trait/multiple-def-uses-in-one-fn-infer.stderr
new file mode 100644 (file)
index 0000000..3f57612
--- /dev/null
@@ -0,0 +1,14 @@
+error: concrete type differs from previous defining opaque type use
+  --> $DIR/multiple-def-uses-in-one-fn-infer.rs:9:1
+   |
+LL | fn g<A, B>() -> (Y<A, B>, Y<B, A>) {
+   | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ expected `i64`, got `i32`
+   |
+note: previous use here
+  --> $DIR/multiple-def-uses-in-one-fn-infer.rs:9:1
+   |
+LL | fn g<A, B>() -> (Y<A, B>, Y<B, A>) {
+   | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
+
+error: aborting due to previous error
+