Skip to content

Commit

Permalink
Fix location of error message explanation
Browse files Browse the repository at this point in the history
  • Loading branch information
sledgehammervampire committed Jan 10, 2021
1 parent 5ccef56 commit 12f1795
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 15 deletions.
22 changes: 12 additions & 10 deletions compiler/rustc_mir/src/borrow_check/diagnostics/conflict_errors.rs
Expand Up @@ -1323,16 +1323,6 @@ impl<'cx, 'tcx> MirBorrowckCtxt<'cx, 'tcx> {
suggestion,
Applicability::MachineApplicable,
);
if let Some(generator_kind) = use_span.generator_kind() {
if let GeneratorKind::Async(_) = generator_kind {
err.note(
"borrows cannot be held across a yield point, because the stack space of the current \
function is not preserved",
);
err.help("see https://rust-lang.github.io/async-book/03_async_await/01_chapter.html#awaiting-on-a-multithreaded-executor \
for more information");
}
}

let msg = match category {
ConstraintCategory::Return(_) | ConstraintCategory::OpaqueType => {
Expand All @@ -1349,6 +1339,18 @@ impl<'cx, 'tcx> MirBorrowckCtxt<'cx, 'tcx> {
),
};
err.span_note(constraint_span, &msg);
if let ConstraintCategory::CallArgument = category {
if let Some(generator_kind) = use_span.generator_kind() {
if let GeneratorKind::Async(_) = generator_kind {
err.note(
"borrows cannot be held across a yield point, because the stack \
space of the current function is not preserved",
);
err.help("see https://rust-lang.github.io/async-book/03_async_await/01_chapter.html#awaiting-on-a-multithreaded-executor \
for more information");
}
}
}
err
}

Expand Down
6 changes: 3 additions & 3 deletions src/test/ui/async-await/issues/issue-78938-async-block.rs
Expand Up @@ -16,7 +16,7 @@ fn game_loop(v: Arc<Vec<usize>>) {}
fn spawn<F>(future: F) -> JoinHandle
where
F: Future + Send + 'static,
F::Output: Send + 'static,
F::Output: Send + 'static,
{
loop {}
}
Expand All @@ -26,8 +26,8 @@ struct JoinHandle;
impl Future for JoinHandle {
type Output = ();
fn poll(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Self::Output> {
loop {}
loop {}
}
}

fn main() {}
fn main() {}
4 changes: 2 additions & 2 deletions src/test/ui/async-await/issues/issue-78938-async-block.stderr
Expand Up @@ -8,8 +8,6 @@ LL | | game_loop(Arc::clone(&room_ref))
LL | | });
| |_____^ may outlive borrowed value `room_ref`
|
= note: borrows cannot be held across a yield point, because the stack space of the current function is not preserved
= help: see https://rust-lang.github.io/async-book/03_async_await/01_chapter.html#awaiting-on-a-multithreaded-executor for more information
note: function requires argument type to outlive `'static`
--> $DIR/issue-78938-async-block.rs:8:33
|
Expand All @@ -18,6 +16,8 @@ LL | let gameloop_handle = spawn(async {
LL | | game_loop(Arc::clone(&room_ref))
LL | | });
| |_____^
= note: borrows cannot be held across a yield point, because the stack space of the current function is not preserved
= help: see https://rust-lang.github.io/async-book/03_async_await/01_chapter.html#awaiting-on-a-multithreaded-executor for more information
help: to force the async block to take ownership of `room_ref` (and any other referenced variables), use the `move` keyword
|
LL | let gameloop_handle = spawn(async move {
Expand Down

0 comments on commit 12f1795

Please sign in to comment.