Skip to content

Commit d8afa23

Browse files
committed
---
yaml --- r: 121573 b: refs/heads/auto c: 9a99084 h: refs/heads/master i: 121571: 9aacb34 v: v3
1 parent 5940d79 commit d8afa23

File tree

4 files changed

+39
-3
lines changed

4 files changed

+39
-3
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -13,7 +13,7 @@ refs/heads/try3: 9387340aab40a73e8424c48fd42f0c521a4875c0
1313
refs/tags/release-0.3.1: 495bae036dfe5ec6ceafd3312b4dca48741e845b
1414
refs/tags/release-0.4: e828ea2080499553b97dfe33b3f4d472b4562ad7
1515
refs/tags/release-0.5: 7e3bcfbf21278251ee936ad53e92e9b719702d73
16-
refs/heads/auto: 4c33a14cc546ddacd5398cebf57aa5ac574cfea7
16+
refs/heads/auto: 9a9908405d499e333baa20375bcaadfcca5459de
1717
refs/heads/servo: af82457af293e2a842ba6b7759b70288da276167
1818
refs/tags/release-0.6: b4ebcfa1812664df5e142f0134a5faea3918544c
1919
refs/tags/0.1: b19db808c2793fe2976759b85a355c3ad8c8b336

branches/auto/src/libnative/io/process.rs

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -533,6 +533,10 @@ fn spawn_process_os(cfg: ProcessConfig,
533533

534534
let dirp = cfg.cwd.map(|c| c.with_ref(|p| p)).unwrap_or(ptr::null());
535535

536+
let cfg = unsafe {
537+
mem::transmute::<ProcessConfig,ProcessConfig<'static>>(cfg)
538+
};
539+
536540
with_envp(cfg.env, proc(envp) {
537541
with_argv(cfg.program, cfg.args, proc(argv) unsafe {
538542
let (mut input, mut output) = try!(pipe());

branches/auto/src/librustc/middle/kind.rs

Lines changed: 8 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -198,8 +198,14 @@ fn with_appropriate_checker(cx: &Context,
198198
let fty = ty::node_id_to_type(cx.tcx, id);
199199
match ty::get(fty).sty {
200200
ty::ty_closure(box ty::ClosureTy {
201-
store: ty::UniqTraitStore, bounds, ..
202-
}) => b(|cx, fv| check_for_uniq(cx, fv, bounds)),
201+
store: ty::UniqTraitStore,
202+
bounds: mut bounds, ..
203+
}) => {
204+
// Procs can't close over non-static references!
205+
bounds.add(ty::BoundStatic);
206+
207+
b(|cx, fv| check_for_uniq(cx, fv, bounds))
208+
}
203209

204210
ty::ty_closure(box ty::ClosureTy {
205211
store: ty::RegionTraitStore(region, _), bounds, ..
Lines changed: 26 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,26 @@
1+
// Copyright 2014 The Rust Project Developers. See the COPYRIGHT
2+
// file at the top-level directory of this distribution and at
3+
// http://rust-lang.org/COPYRIGHT.
4+
//
5+
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6+
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7+
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8+
// option. This file may not be copied, modified, or distributed
9+
// except according to those terms.
10+
11+
fn main() {
12+
let mut x = Some(1);
13+
let mut p: proc(&mut Option<int>) = proc(_) {};
14+
match x {
15+
Some(ref y) => {
16+
p = proc(z: &mut Option<int>) {
17+
*z = None;
18+
let _ = y;
19+
//~^ ERROR cannot capture variable of type `&int`, which does not fulfill `'static`
20+
};
21+
}
22+
None => {}
23+
}
24+
p(&mut x);
25+
}
26+

0 commit comments

Comments
 (0)