summaryrefslogtreecommitdiffstats
path: root/tests/ui/borrowck/borrowck-escaping-closure-error-1.rs
blob: 11c0610aa0caedc9dc0ef66e39b06d24fad7a751 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
use std::thread::spawn;

// Test that we give a custom error (E0373) for the case where a
// closure is escaping current frame, and offer a suggested code edit.
// I refrained from including the precise message here, but the
// original text as of the time of this writing is:
//
//    closure may outlive the current function, but it borrows `books`,
//    which is owned by the current function

fn main() {
    let mut books = vec![1,2,3];
    spawn(|| books.push(4));
    //~^ ERROR E0373
}