summaryrefslogtreecommitdiffstats
path: root/tests/ui/borrowck/reborrow-sugg-move-then-borrow.rs
blob: 31eba074008467132fce9e876ee75016cbe5948b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
// Tests the suggestion to reborrow the first move site
// when we move then borrow a `&mut` ref.

struct State;

impl IntoIterator for &mut State {
    type IntoIter = std::vec::IntoIter<()>;
    type Item = ();

    fn into_iter(self) -> Self::IntoIter {
        vec![].into_iter()
    }
}

fn once(f: impl FnOnce()) {}

fn fill_memory_blocks_mt(state: &mut State) {
    for _ in state {}
    //~^ HELP consider creating a fresh reborrow of `state` here
    fill_segment(state);
    //~^ ERROR borrow of moved value: `state`
}

fn fill_segment(state: &mut State) {}

fn main() {}