summaryrefslogtreecommitdiffstats
path: root/tests/ui/proc-macro/auxiliary/edition-gated-async-move-syntax.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-19 09:26:03 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-19 09:26:03 +0000
commit9918693037dce8aa4bb6f08741b6812923486c18 (patch)
tree21d2b40bec7e6a7ea664acee056eb3d08e15a1cf /tests/ui/proc-macro/auxiliary/edition-gated-async-move-syntax.rs
parentReleasing progress-linux version 1.75.0+dfsg1-5~progress7.99u1. (diff)
downloadrustc-9918693037dce8aa4bb6f08741b6812923486c18.tar.xz
rustc-9918693037dce8aa4bb6f08741b6812923486c18.zip
Merging upstream version 1.76.0+dfsg1.
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'tests/ui/proc-macro/auxiliary/edition-gated-async-move-syntax.rs')
-rw-r--r--tests/ui/proc-macro/auxiliary/edition-gated-async-move-syntax.rs39
1 files changed, 39 insertions, 0 deletions
diff --git a/tests/ui/proc-macro/auxiliary/edition-gated-async-move-syntax.rs b/tests/ui/proc-macro/auxiliary/edition-gated-async-move-syntax.rs
new file mode 100644
index 000000000..ce7e60356
--- /dev/null
+++ b/tests/ui/proc-macro/auxiliary/edition-gated-async-move-syntax.rs
@@ -0,0 +1,39 @@
+// force-host
+// no-prefer-dynamic
+
+// Proc macro helper for issue #89699, used by tests/ui/proc-macro/edition-gated-async-move-
+// syntax-issue89699.rs, emitting an `async move` closure. This syntax is only available in
+// editions 2018 and up, but is used in edition 2015 in the test.
+
+#![crate_type = "proc-macro"]
+
+extern crate proc_macro;
+use proc_macro::*;
+
+#[proc_macro_attribute]
+pub fn foo(_attr: TokenStream, item: TokenStream) -> TokenStream {
+ let tt = item.into_iter().next().unwrap();
+ let sp = tt.span();
+ let mut arg = TokenStream::new();
+ let mut g = Group::new(Delimiter::Brace, TokenStream::new());
+ g.set_span(sp);
+ arg.extend([
+ TokenTree::Ident(Ident::new("async", sp)),
+ TokenTree::Ident(Ident::new("move", sp)),
+ TokenTree::Group(g),
+ ]);
+ let mut body = TokenStream::new();
+ body.extend([
+ TokenTree::Ident(Ident::new("async_main", sp)),
+ TokenTree::Group(Group::new(Delimiter::Parenthesis, arg)),
+ ]);
+
+ let mut ret = TokenStream::new();
+ ret.extend([
+ TokenTree::Ident(Ident::new("fn", sp)),
+ TokenTree::Ident(Ident::new("main", sp)),
+ TokenTree::Group(Group::new(Delimiter::Parenthesis, TokenStream::new())),
+ TokenTree::Group(Group::new(Delimiter::Brace, body)),
+ ]);
+ ret
+}