Skip to content

Commit 12b757b

Browse files
committed
auto merge of #17246 : bkoropoff/rust/issue-17216, r=pnkfelix
Trans the cleanup scope of for loop bindings so we don't leak resources. Regression test included. Closes #17216
2 parents 88cb454 + f1c4e47 commit 12b757b

File tree

2 files changed

+36
-1
lines changed

2 files changed

+36
-1
lines changed

src/librustc/middle/trans/controlflow.rs

+4-1
Original file line numberDiff line numberDiff line change
@@ -355,7 +355,10 @@ pub fn trans_for<'blk, 'tcx>(mut bcx: Block<'blk, 'tcx>,
355355

356356
// Codegen the body.
357357
body_bcx_out = trans_block(body_bcx_out, body, expr::Ignore);
358-
body_bcx_out.fcx.pop_custom_cleanup_scope(binding_cleanup_scope);
358+
body_bcx_out =
359+
body_bcx_out.fcx
360+
.pop_and_trans_custom_cleanup_scope(body_bcx_out,
361+
binding_cleanup_scope);
359362
body_bcx_out =
360363
body_bcx_out.fcx
361364
.pop_and_trans_custom_cleanup_scope(body_bcx_out,

src/test/run-pass/issue-17216.rs

+32
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,32 @@
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+
#![feature(unsafe_destructor)]
12+
13+
struct Leak<'a> {
14+
dropped: &'a mut bool
15+
}
16+
17+
#[unsafe_destructor]
18+
impl<'a> Drop for Leak<'a> {
19+
fn drop(&mut self) {
20+
*self.dropped = true;
21+
}
22+
}
23+
24+
fn main() {
25+
let mut dropped = false;
26+
{
27+
let leak = Leak { dropped: &mut dropped };
28+
for ((), leaked) in Some(((),leak)).move_iter() {}
29+
}
30+
31+
assert!(dropped);
32+
}

0 commit comments

Comments
 (0)