diff options
| author | bors <bors@rust-lang.org> | 2016-02-08 17:05:21 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2016-02-08 17:05:21 +0000 |
| commit | 26105b1a3765a73bab44fb18ccbd5a4635018fdf (patch) | |
| tree | e73d37808093f8bd4e82d3a1e034da4b9b12767f /src | |
| parent | 04f12ef4f775cf367f2e34b99d498d51e677a15e (diff) | |
| parent | f08626bc9b99eef97dbb78a8ac5f7dec958c0be7 (diff) | |
| download | rust-26105b1a3765a73bab44fb18ccbd5a4635018fdf.tar.gz rust-26105b1a3765a73bab44fb18ccbd5a4635018fdf.zip | |
Auto merge of #31462 - thepowersgang:fix_29946, r=dotdash
Generates drop calls at the end of the Fn/FnMut -> FnOnce closure shim Fix #29946
Diffstat (limited to 'src')
| -rw-r--r-- | src/librustc_trans/trans/closure.rs | 2 | ||||
| -rw-r--r-- | src/test/run-pass/issue-29948.rs | 32 |
2 files changed, 33 insertions, 1 deletions
diff --git a/src/librustc_trans/trans/closure.rs b/src/librustc_trans/trans/closure.rs index 5bdfc099f08..c2d6422e3b0 100644 --- a/src/librustc_trans/trans/closure.rs +++ b/src/librustc_trans/trans/closure.rs @@ -421,7 +421,7 @@ fn trans_fn_once_adapter_shim<'a, 'tcx>( } }, ArgVals(&llargs[(self_idx + 1)..]), dest).bcx; - fcx.pop_custom_cleanup_scope(self_scope); + fcx.pop_and_trans_custom_cleanup_scope(bcx, self_scope); finish_fn(&fcx, bcx, sig.output, DebugLoc::None); diff --git a/src/test/run-pass/issue-29948.rs b/src/test/run-pass/issue-29948.rs new file mode 100644 index 00000000000..ec2b53313fa --- /dev/null +++ b/src/test/run-pass/issue-29948.rs @@ -0,0 +1,32 @@ +// 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. + +struct Foo<'a>(&'a mut bool); + +impl<'a> Drop for Foo<'a> { + fn drop(&mut self) { + *self.0 = true; + } +} + +fn f<T: FnOnce()>(t: T) { + t() +} + +fn main() { + let mut ran_drop = false; + { + let x = Foo(&mut ran_drop); + let x = move || { let _ = x; }; + f(x); + } + assert!(ran_drop); +} + |
