diff options
| author | Michael Howell <michael@notriddle.com> | 2021-08-21 12:51:34 -0700 |
|---|---|---|
| committer | Michael Howell <michael@notriddle.com> | 2021-08-28 12:18:46 -0700 |
| commit | fe1a7f71fbf3cf845a09a9b333a6adcf7e839607 (patch) | |
| tree | 5b43977dd3f95093d053e1b069541852bfc46dfd /compiler/rustc_ast_lowering | |
| parent | 9583fd1bdd0127328e25e5b8c24dff575ec2c86b (diff) | |
| download | rust-fe1a7f71fbf3cf845a09a9b333a6adcf7e839607.tar.gz rust-fe1a7f71fbf3cf845a09a9b333a6adcf7e839607.zip | |
rustc: use more correct span data in for loop desugaring
Before:
help: consider adding semicolon after the expression so its temporaries are dropped sooner, before the local variables declared by the block are dropped
|
LL | for x in DroppingSlice(&*v).iter(); {
| +
After:
help: consider adding semicolon after the expression so its temporaries are dropped sooner, before the local variables declared by the block are dropped
|
LL | };
| +
This seems like a reasonable fix: since the desugared "expr_drop_temps_mut"
contains the entire desugared loop construct, its span should contain the
entire loop construct as well.
Diffstat (limited to 'compiler/rustc_ast_lowering')
| -rw-r--r-- | compiler/rustc_ast_lowering/src/expr.rs | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/compiler/rustc_ast_lowering/src/expr.rs b/compiler/rustc_ast_lowering/src/expr.rs index bf7589e84ad..487e229543a 100644 --- a/compiler/rustc_ast_lowering/src/expr.rs +++ b/compiler/rustc_ast_lowering/src/expr.rs @@ -1401,8 +1401,13 @@ impl<'hir> LoweringContext<'_, 'hir> { ) }; + // #82462: to correctly diagnose borrow errors, the block that contains + // the iter expr needs to have a span that covers the loop body. + let desugared_full_span = + self.mark_span_with_reason(DesugaringKind::ForLoop(ForLoopLoc::Head), e.span, None); + let match_expr = self.arena.alloc(self.expr_match( - desugared_span, + desugared_full_span, into_iter_expr, arena_vec![self; iter_arm], hir::MatchSource::ForLoopDesugar, @@ -1416,7 +1421,7 @@ impl<'hir> LoweringContext<'_, 'hir> { // surrounding scope of the `match` since the `match` is not a terminating scope. // // Also, add the attributes to the outer returned expr node. - self.expr_drop_temps_mut(desugared_span, match_expr, attrs.into()) + self.expr_drop_temps_mut(desugared_full_span, match_expr, attrs.into()) } /// Desugar `ExprKind::Try` from: `<expr>?` into: |
