rust/tests/ui/async-await/task-context-arg.rs
David Lattimore a6292676eb Preserve argument indexes when inlining MIR
We store argument indexes on VarDebugInfo. Unlike the previous method of
relying on the variable index to know whether a variable is an argument,
this survives MIR inlining.

We also no longer check if var.source_info.scope is the outermost scope.
When a function gets inlined, the arguments to the inner function will
no longer be in the outermost scope. What we care about though is
whether they were in the outermost scope prior to inlining, which we
know by whether we assigned an argument index.
2023-04-11 11:07:48 +10:00

26 lines
1000 B
Rust

// Checks that we don't get conflicting arguments in our debug info with a particular async function
// structure.
// edition:2021
// compile-flags: -Cdebuginfo=2
// build-pass
#![crate_type = "lib"]
use std::future::Future;
// The compiler produces a closure as part of this function. That closure initially takes an
// argument _task_context. Later, when the MIR for that closure is transformed into a generator
// state machine, _task_context is demoted to not be an argument, but just part of an unnamed
// argument. If we emit debug info saying that both _task_context and the unnamed argument are both
// argument number 2, then LLVM will fail with "conflicting debug info for argument". See
// https://github.com/rust-lang/rust/pull/109466#issuecomment-1500879195 for details.
async fn recv_unit() {
std::future::ready(()).await;
}
pub fn poll_recv() {
// This box is necessary in order to reproduce the problem.
let _: Box<dyn Future<Output = ()>> = Box::new(recv_unit());
}