]> git.lizzy.rs Git - rust.git/commitdiff
Emit destructor invocation in FnOnce shim for Fn/FnMut
authorJohn Hodge <tpg@ucc.asn.au>
Sun, 7 Feb 2016 11:35:39 +0000 (19:35 +0800)
committerJohn Hodge <tpg@ucc.asn.au>
Sun, 7 Feb 2016 13:33:30 +0000 (21:33 +0800)
- Fixes #29946

src/librustc_trans/trans/closure.rs
src/test/run-pass/issue-29948.rs [new file with mode: 0644]

index 5bdfc099f0880eedc40bf0252fcea8d7770899e4..c2d6422e3b0c50e517a2bf696a0aaa13d0e1b1fc 100644 (file)
@@ -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 (file)
index 0000000..ec2b533
--- /dev/null
@@ -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);
+}
+