about summary refs log tree commit diff
path: root/src
diff options
context:
space:
mode:
authorMichael Sullivan <sully@msully.net>2012-06-26 12:47:06 -0700
committerMichael Sullivan <sully@msully.net>2012-06-26 14:05:43 -0700
commit51468b65a48e7e897ff7ac080c33efb7b5ce289d (patch)
treed64a9c0a6dd323674bcfa17fa8f9b5686bd270d0 /src
parentf17ca3f73e8e6196a7549ae0df721828a3dfd262 (diff)
downloadrust-51468b65a48e7e897ff7ac080c33efb7b5ce289d.tar.gz
rust-51468b65a48e7e897ff7ac080c33efb7b5ce289d.zip
Properly cleanup slice literals. Closes #2705.
Diffstat (limited to 'src')
-rw-r--r--src/rustc/middle/trans/tvec.rs7
-rw-r--r--src/test/run-pass/vec-slice-drop.rs15
2 files changed, 22 insertions, 0 deletions
diff --git a/src/rustc/middle/trans/tvec.rs b/src/rustc/middle/trans/tvec.rs
index 4a471bd0059..58d415ad266 100644
--- a/src/rustc/middle/trans/tvec.rs
+++ b/src/rustc/middle/trans/tvec.rs
@@ -152,8 +152,15 @@ fn trans_evec(bcx: block, args: [@ast::expr]/~,
           }
           ast::vstore_slice(_) {
             let n = vec::len(args);
+            // Make a fake type to use for the cleanup
+            let ty = ty::mk_evec(bcx.tcx(),
+                                 {ty: unit_ty, mutbl: ast::m_mutbl},
+                                 ty::vstore_fixed(n));
+
             let n = C_uint(ccx, n);
             let vp = base::arrayalloca(bcx, llunitty, n);
+            add_clean(bcx, vp, ty);
+
             let len = Mul(bcx, n, unit_sz);
 
             let p = base::alloca(bcx, T_struct([T_ptr(llunitty),
diff --git a/src/test/run-pass/vec-slice-drop.rs b/src/test/run-pass/vec-slice-drop.rs
new file mode 100644
index 00000000000..e8709d8f108
--- /dev/null
+++ b/src/test/run-pass/vec-slice-drop.rs
@@ -0,0 +1,15 @@
+// Make sure that destructors get run on slice literals
+class foo {
+    let x: @mut int;
+    new(x: @mut int) { self.x = x; }
+    drop { *self.x += 1; }
+}
+
+fn main() {
+    let x = @mut 0;
+    {
+        let l = [foo(x)]/&;
+        assert *l[0].x == 0;
+    }
+    assert *x == 1;
+}