diff options
| author | Cameron Zwarich <zwarich@mozilla.com> | 2014-06-06 11:59:33 -0700 |
|---|---|---|
| committer | Cameron Zwarich <zwarich@mozilla.com> | 2014-06-06 11:59:33 -0700 |
| commit | f1542a6a7da088f99bfe2963d29e6ea4b451b432 (patch) | |
| tree | 14d13a9e51dc5979c16f473ff9b718a551af90ba | |
| parent | 74eb4b4b5713be0d80b666f0032d7d7c111db368 (diff) | |
| download | rust-f1542a6a7da088f99bfe2963d29e6ea4b451b432.tar.gz rust-f1542a6a7da088f99bfe2963d29e6ea4b451b432.zip | |
Add a test for borrowck errors with multiple closure captures.
When converting check_loans to use ExprUseVisitor I encountered a few issues where the wrong number of errors were being emitted for multiple closure captures, but there is no existing test for this.
| -rw-r--r-- | src/test/compile-fail/borrowck-multiple-captures.rs | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/src/test/compile-fail/borrowck-multiple-captures.rs b/src/test/compile-fail/borrowck-multiple-captures.rs new file mode 100644 index 00000000000..e12d2b91479 --- /dev/null +++ b/src/test/compile-fail/borrowck-multiple-captures.rs @@ -0,0 +1,64 @@ +// Copyright 2014 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or +// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license +// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +use std::task; + +fn borrow<T>(_: &T) { } + +fn different_vars_after_borrows() { + let x1 = box 1; + let p1 = &x1; + let x2 = box 2; + let p2 = &x2; + task::spawn(proc() { + drop(x1); //~ ERROR cannot move `x1` into closure because it is borrowed + drop(x2); //~ ERROR cannot move `x2` into closure because it is borrowed + }); + borrow(&*p1); + borrow(&*p2); +} + +fn different_vars_after_moves() { + let x1 = box 1; + drop(x1); + let x2 = box 2; + drop(x2); + task::spawn(proc() { + drop(x1); //~ ERROR capture of moved value: `x1` + drop(x2); //~ ERROR capture of moved value: `x2` + }); +} + +fn same_var_after_borrow() { + let x = box 1; + let p = &x; + task::spawn(proc() { + drop(x); //~ ERROR cannot move `x` into closure because it is borrowed + drop(x); //~ ERROR use of moved value: `x` + }); + borrow(&*p); +} + +fn same_var_after_move() { + let x = box 1; + drop(x); + task::spawn(proc() { + drop(x); //~ ERROR capture of moved value: `x` + drop(x); //~ ERROR use of moved value: `x` + }); +} + +fn main() { + different_vars_after_borrows(); + different_vars_after_moves(); + same_var_after_borrow(); + same_var_after_move(); +} + |
