diff options
| author | bors <bors@rust-lang.org> | 2024-02-09 21:06:12 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2024-02-09 21:06:12 +0000 |
| commit | d44e3b95cb9d410d89cb8ab3233906a33f43756a (patch) | |
| tree | 0e7416fd47b7d79015233d6516cdece2ebd0fe88 /tests/codegen | |
| parent | f4cfd872028398da2b2d85c368c51f4d007dc6af (diff) | |
| parent | 3c1b7a741f4adcc29324836db6e4fe078589debb (diff) | |
| download | rust-d44e3b95cb9d410d89cb8ab3233906a33f43756a.tar.gz rust-d44e3b95cb9d410d89cb8ab3233906a33f43756a.zip | |
Auto merge of #120852 - matthiaskrgr:rollup-01pr8gj, r=matthiaskrgr
Rollup of 11 pull requests Successful merges: - #120351 (Implement SystemTime for UEFI) - #120354 (improve normalization of `Pointee::Metadata`) - #120776 (Move path implementations into `sys`) - #120790 (better error message on download CI LLVM failure) - #120806 (Clippy subtree update) - #120815 (Improve `Option::inspect` docs) - #120822 (Emit more specific diagnostics when enums fail to cast with `as`) - #120827 (Print image input file and checksum in CI only) - #120836 (hide impls if trait bound is proven from env) - #120844 (Build DebugInfo for async closures) - #120851 (Remove duplicate release note) r? `@ghost` `@rustbot` modify labels: rollup
Diffstat (limited to 'tests/codegen')
| -rw-r--r-- | tests/codegen/async-closure-debug.rs | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/tests/codegen/async-closure-debug.rs b/tests/codegen/async-closure-debug.rs new file mode 100644 index 00000000000..6718d2b6627 --- /dev/null +++ b/tests/codegen/async-closure-debug.rs @@ -0,0 +1,21 @@ +// Just make sure that async closures don't ICE. +// +// compile-flags: -C debuginfo=2 --edition=2018 +// ignore-msvc + +// CHECK-DAG: [[GEN_FN:!.*]] = !DINamespace(name: "async_closure_test" +// CHECK-DAG: [[CLOSURE:!.*]] = !DICompositeType(tag: DW_TAG_structure_type, name: "{closure_env#0}", scope: [[GEN_FN]] +// CHECK-DAG: [[UPVAR:!.*]] = !DIDerivedType(tag: DW_TAG_member, name: "upvar", scope: [[CLOSURE]] + +#![feature(async_closure)] + +fn async_closure_test(upvar: &str) -> impl async Fn() + '_ { + async move || { + let hello = String::from("hello"); + println!("{hello}, {upvar}"); + } +} + +fn main() { + let _async_closure = async_closure_test("world"); +} |
