diff options
| author | Michael Goulet <michael@errs.io> | 2024-02-09 15:53:55 +0000 |
|---|---|---|
| committer | Michael Goulet <michael@errs.io> | 2024-02-09 16:01:29 +0000 |
| commit | 34ed554d816ff79206241084cb04b1a9ef2bfcd1 (patch) | |
| tree | 1e2ce7540d6ae4c6ccc3c47110a24f6fd6dbd2cd /tests/codegen | |
| parent | 972452c4473b2d8f6f6415614f915296bfc34f12 (diff) | |
| download | rust-34ed554d816ff79206241084cb04b1a9ef2bfcd1.tar.gz rust-34ed554d816ff79206241084cb04b1a9ef2bfcd1.zip | |
Build DebugInfo for coroutine-closure
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"); +} |
