summaryrefslogtreecommitdiffstats
path: root/src/test/ui/async-await/in-trait/async-example-desugared-in-trait.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/test/ui/async-await/in-trait/async-example-desugared-in-trait.rs')
-rw-r--r--src/test/ui/async-await/in-trait/async-example-desugared-in-trait.rs21
1 files changed, 21 insertions, 0 deletions
diff --git a/src/test/ui/async-await/in-trait/async-example-desugared-in-trait.rs b/src/test/ui/async-await/in-trait/async-example-desugared-in-trait.rs
new file mode 100644
index 000000000..feeda719e
--- /dev/null
+++ b/src/test/ui/async-await/in-trait/async-example-desugared-in-trait.rs
@@ -0,0 +1,21 @@
+// check-pass
+// edition: 2021
+
+#![feature(async_fn_in_trait)]
+#![feature(return_position_impl_trait_in_trait)]
+#![allow(incomplete_features)]
+
+use std::future::Future;
+
+trait MyTrait {
+ fn foo(&self) -> impl Future<Output = i32> + '_;
+}
+
+impl MyTrait for i32 {
+ // This will break once a PR that implements #102745 is merged
+ async fn foo(&self) -> i32 {
+ *self
+ }
+}
+
+fn main() {}