forked from rust-lang/rust
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Rollup merge of rust-lang#55781 - pnkfelix:issue-54382-more-precise-s…
…pans-for-temps-and-their-drops, r=davidtwco More precise spans for temps and their drops This PR has two main enhancements: 1. when possible during code generation for a statement (like `expr();`), pass along the span of a statement, and then attribute the drops of temporaries from that statement to the statement's end-point (which will be the semicolon if it is a statement that is terminating by a semicolon). 2. when evaluating a block expression into a MIR temp, use the span of the block's tail expression (rather than the span of whole block including its statements and curly-braces) for the span of the temp. Each of these individually increases the precision of our diagnostic output; together they combine to make a much clearer picture about the control flow through the spans. Fix rust-lang#54382
- Loading branch information
Showing
11 changed files
with
194 additions
and
34 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
20 changes: 20 additions & 0 deletions
20
src/test/ui/nll/issue-54382-use-span-of-tail-of-block.nll.stderr
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
error[E0597]: `_thing1` does not live long enough | ||
--> $DIR/issue-54382-use-span-of-tail-of-block.rs:7:29 | ||
| | ||
LL | D("other").next(&_thing1) | ||
| ----------------^^^^^^^^- | ||
| | | | ||
| | borrowed value does not live long enough | ||
| a temporary with access to the borrow is created here ... | ||
LL | } | ||
LL | } | ||
| - `_thing1` dropped here while still borrowed | ||
LL | | ||
LL | ; | ||
| - ... and the borrow might be used here, when that temporary is dropped and runs the `Drop` code for type `D` | ||
| | ||
= note: The temporary is part of an expression at the end of a block. Consider adding semicolon after the expression so its temporaries are dropped sooner, before the local variables declared by the block are dropped. | ||
|
||
error: aborting due to previous error | ||
|
||
For more information about this error, try `rustc --explain E0597`. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
fn main() { | ||
{ | ||
let mut _thing1 = D(Box::new("thing1")); | ||
{ | ||
let _thing2 = D("thing2"); | ||
side_effects(); | ||
D("other").next(&_thing1) | ||
} | ||
} | ||
|
||
; | ||
} | ||
|
||
#[derive(Debug)] | ||
struct D<T: std::fmt::Debug>(T); | ||
|
||
impl<T: std::fmt::Debug> Drop for D<T> { | ||
fn drop(&mut self) { | ||
println!("dropping {:?})", self); | ||
} | ||
} | ||
|
||
impl<T: std::fmt::Debug> D<T> { | ||
fn next<U: std::fmt::Debug>(&self, _other: U) -> D<U> { D(_other) } | ||
fn end(&self) { } | ||
} | ||
|
||
fn side_effects() { } |
15 changes: 15 additions & 0 deletions
15
src/test/ui/nll/issue-54382-use-span-of-tail-of-block.stderr
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
error[E0597]: `_thing1` does not live long enough | ||
--> $DIR/issue-54382-use-span-of-tail-of-block.rs:7:30 | ||
| | ||
LL | D("other").next(&_thing1) | ||
| ^^^^^^^ borrowed value does not live long enough | ||
LL | } | ||
LL | } | ||
| - `_thing1` dropped here while still borrowed | ||
LL | | ||
LL | ; | ||
| - borrowed value needs to live until here | ||
|
||
error: aborting due to previous error | ||
|
||
For more information about this error, try `rustc --explain E0597`. |