mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-02 07:22:42 +00:00
62 lines
1.7 KiB
Rust
62 lines
1.7 KiB
Rust
|
// rust-lang/rust#55492: errors detected during MIR-borrowck's
|
||
|
// analysis of a closure body may only be caught when AST-borrowck
|
||
|
// looks at some parent.
|
||
|
|
||
|
// revisions: ast migrate nll
|
||
|
|
||
|
// Since we are testing nll (and migration) explicitly as a separate
|
||
|
// revisions, don't worry about the --compare-mode=nll on this test.
|
||
|
|
||
|
// ignore-compare-mode-nll
|
||
|
|
||
|
//[ast]compile-flags: -Z borrowck=ast
|
||
|
//[migrate]compile-flags: -Z borrowck=migrate -Z two-phase-borrows
|
||
|
//[nll]compile-flags: -Z borrowck=mir -Z two-phase-borrows
|
||
|
|
||
|
|
||
|
// transcribed from borrowck-closures-unique.rs
|
||
|
mod borrowck_closures_unique {
|
||
|
pub fn e(x: &'static mut isize) {
|
||
|
static mut Y: isize = 3;
|
||
|
let mut c1 = |y: &'static mut isize| x = y;
|
||
|
unsafe { c1(&mut Y); }
|
||
|
}
|
||
|
}
|
||
|
|
||
|
mod borrowck_closures_unique_grandparent {
|
||
|
pub fn ee(x: &'static mut isize) {
|
||
|
static mut Z: isize = 3;
|
||
|
let mut c1 = |z: &'static mut isize| {
|
||
|
let mut c2 = |y: &'static mut isize| x = y;
|
||
|
c2(z);
|
||
|
};
|
||
|
unsafe { c1(&mut Z); }
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// adapted from mutability_errors.rs
|
||
|
mod mutability_errors {
|
||
|
pub fn capture_assign_whole(x: (i32,)) {
|
||
|
|| { x = (1,); };
|
||
|
}
|
||
|
pub fn capture_assign_part(x: (i32,)) {
|
||
|
|| { x.0 = 1; };
|
||
|
}
|
||
|
pub fn capture_reborrow_whole(x: (i32,)) {
|
||
|
|| { &mut x; };
|
||
|
}
|
||
|
pub fn capture_reborrow_part(x: (i32,)) {
|
||
|
|| { &mut x.0; };
|
||
|
}
|
||
|
}
|
||
|
|
||
|
fn main() {
|
||
|
static mut X: isize = 2;
|
||
|
unsafe { borrowck_closures_unique::e(&mut X); }
|
||
|
|
||
|
mutability_errors::capture_assign_whole((1000,));
|
||
|
mutability_errors::capture_assign_part((2000,));
|
||
|
mutability_errors::capture_reborrow_whole((3000,));
|
||
|
mutability_errors::capture_reborrow_part((4000,));
|
||
|
}
|