Leave promoteds untainted by errors when borrowck fails
Previously, when borrowck failed it would taint all promoteds within the MIR body. An attempt to evaluated the promoteds would subsequently fail with spurious "note: erroneous constant used". For example: ```console ... note: erroneous constant used --> tests/ui/borrowck/tainted-promoteds.rs:7:9 | 7 | a = &0 * &1 * &2 * &3; | ^^ note: erroneous constant used --> tests/ui/borrowck/tainted-promoteds.rs:7:14 | 7 | a = &0 * &1 * &2 * &3; | ^^ note: erroneous constant used --> tests/ui/borrowck/tainted-promoteds.rs:7:19 | 7 | a = &0 * &1 * &2 * &3; | ^^ note: erroneous constant used --> tests/ui/borrowck/tainted-promoteds.rs:7:24 | 7 | a = &0 * &1 * &2 * &3; | ^^ ``` Borrowck failure doesn't indicate that there is anything wrong with promoteds. Leave them untainted.
This commit is contained in:
parent
f2eb9f85b9
commit
c678acd3a2
3 changed files with 27 additions and 4 deletions
|
@ -616,13 +616,10 @@ fn promoted_mir(tcx: TyCtxt<'_>, def: LocalDefId) -> &IndexVec<Promoted, Body<'_
|
|||
return tcx.arena.alloc(IndexVec::new());
|
||||
}
|
||||
|
||||
let tainted_by_errors = tcx.mir_borrowck(def).tainted_by_errors;
|
||||
tcx.ensure_with_value().mir_borrowck(def);
|
||||
let mut promoted = tcx.mir_promoted(def).1.steal();
|
||||
|
||||
for body in &mut promoted {
|
||||
if let Some(error_reported) = tainted_by_errors {
|
||||
body.tainted_by_errors = Some(error_reported);
|
||||
}
|
||||
run_analysis_to_runtime_passes(tcx, body);
|
||||
}
|
||||
|
||||
|
|
12
tests/ui/borrowck/tainted-promoteds.rs
Normal file
12
tests/ui/borrowck/tainted-promoteds.rs
Normal file
|
@ -0,0 +1,12 @@
|
|||
// Regression test for issue #110856, where a borrowck error for a MIR tainted
|
||||
// all promoteds within. This in turn generated a spurious "erroneous constant
|
||||
// used" note when trying to evaluate a promoted.
|
||||
|
||||
pub fn f() -> u32 {
|
||||
let a = 0;
|
||||
a = &0 * &1 * &2 * &3;
|
||||
//~^ ERROR: cannot assign twice to immutable variable
|
||||
a
|
||||
}
|
||||
|
||||
fn main() {}
|
14
tests/ui/borrowck/tainted-promoteds.stderr
Normal file
14
tests/ui/borrowck/tainted-promoteds.stderr
Normal file
|
@ -0,0 +1,14 @@
|
|||
error[E0384]: cannot assign twice to immutable variable `a`
|
||||
--> $DIR/tainted-promoteds.rs:7:5
|
||||
|
|
||||
LL | let a = 0;
|
||||
| -
|
||||
| |
|
||||
| first assignment to `a`
|
||||
| help: consider making this binding mutable: `mut a`
|
||||
LL | a = &0 * &1 * &2 * &3;
|
||||
| ^^^^^^^^^^^^^^^^^^^^^ cannot assign twice to immutable variable
|
||||
|
||||
error: aborting due to previous error
|
||||
|
||||
For more information about this error, try `rustc --explain E0384`.
|
Loading…
Add table
Reference in a new issue