about summary refs log tree commit diff
path: root/tests/codegen
diff options
context:
space:
mode:
authorMichael Goulet <michael@errs.io>2024-02-09 15:53:55 +0000
committerMichael Goulet <michael@errs.io>2024-02-09 16:01:29 +0000
commit34ed554d816ff79206241084cb04b1a9ef2bfcd1 (patch)
tree1e2ce7540d6ae4c6ccc3c47110a24f6fd6dbd2cd /tests/codegen
parent972452c4473b2d8f6f6415614f915296bfc34f12 (diff)
downloadrust-34ed554d816ff79206241084cb04b1a9ef2bfcd1.tar.gz
rust-34ed554d816ff79206241084cb04b1a9ef2bfcd1.zip
Build DebugInfo for coroutine-closure
Diffstat (limited to 'tests/codegen')
-rw-r--r--tests/codegen/async-closure-debug.rs21
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");
+}