2017-11-06 06:26:34 -06:00
|
|
|
// Basic test for free regions in the NLL code. This test ought to
|
|
|
|
// report an error due to a reborrowing constraint. Right now, we get
|
|
|
|
// a variety of errors from the older, AST-based machinery (notably
|
|
|
|
// borrowck), and then we get the NLL error at the end.
|
|
|
|
|
2018-04-09 04:28:00 -05:00
|
|
|
// compile-flags:-Zborrowck=compare
|
2017-11-06 06:26:34 -06:00
|
|
|
|
|
|
|
struct Map {
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Map {
|
|
|
|
fn get(&self) -> Option<&String> { None }
|
|
|
|
fn set(&mut self, v: String) { }
|
|
|
|
}
|
|
|
|
|
|
|
|
fn ok(map: &mut Map) -> &String {
|
|
|
|
loop {
|
|
|
|
match map.get() {
|
|
|
|
Some(v) => {
|
|
|
|
return v;
|
|
|
|
}
|
|
|
|
None => {
|
2018-05-07 19:02:19 -05:00
|
|
|
map.set(String::new()); // Ideally, this would not error.
|
2017-11-20 06:13:27 -06:00
|
|
|
//~^ ERROR borrowed as immutable (Ast)
|
2018-05-07 19:02:19 -05:00
|
|
|
//~| ERROR borrowed as immutable (Mir)
|
2017-11-06 06:26:34 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn err(map: &mut Map) -> &String {
|
|
|
|
loop {
|
|
|
|
match map.get() {
|
|
|
|
Some(v) => {
|
|
|
|
map.set(String::new()); // Both AST and MIR error here
|
2017-11-20 06:13:27 -06:00
|
|
|
//~^ ERROR borrowed as immutable (Mir)
|
|
|
|
//~| ERROR borrowed as immutable (Ast)
|
2017-11-06 06:26:34 -06:00
|
|
|
return v;
|
|
|
|
}
|
|
|
|
None => {
|
2018-05-07 19:02:19 -05:00
|
|
|
map.set(String::new()); // Ideally, just AST would error here
|
2017-11-20 06:13:27 -06:00
|
|
|
//~^ ERROR borrowed as immutable (Ast)
|
2018-05-07 19:02:19 -05:00
|
|
|
//~| ERROR borrowed as immutable (Mir)
|
2017-11-06 06:26:34 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() { }
|