about summary refs log tree commit diff
path: root/src/liballoc
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2016-02-06 01:24:22 +0000
committerbors <bors@rust-lang.org>2016-02-06 01:24:22 +0000
commit5147c1f2c04f62dceea5feaf6a2dcbebf5cd638f (patch)
tree4d8cd52215cb214be361a4fe29e750597fdd6a61 /src/liballoc
parent34af2de4096b3b1c5d3a5b70171c6e27822aaefb (diff)
parentcaf62ef9846edfd41177b883181c5c045ca69859 (diff)
downloadrust-5147c1f2c04f62dceea5feaf6a2dcbebf5cd638f.tar.gz
rust-5147c1f2c04f62dceea5feaf6a2dcbebf5cd638f.zip
Auto merge of #31307 - nagisa:mir-drop-terminator, r=nikomatsakis
The scope of these refactorings is a little bit bigger than the title implies. See each commit for details.

I’m submitting this for nitpicking now (the first 4 commits), because I feel the basic idea/implementation is sound and should work. I will eventually expand this PR to cover the translator changes necessary for all this to work (+ tests), ~~and perhaps implement a dynamic dropping scheme while I’m at it as well.~~

r? @nikomatsakis
Diffstat (limited to 'src/liballoc')
-rw-r--r--src/liballoc/heap.rs13
1 files changed, 13 insertions, 0 deletions
diff --git a/src/liballoc/heap.rs b/src/liballoc/heap.rs
index 7e7e3c619cb..08b403a60f3 100644
--- a/src/liballoc/heap.rs
+++ b/src/liballoc/heap.rs
@@ -16,6 +16,8 @@
             issue = "27700")]
 
 use core::{isize, usize};
+#[cfg(not(test))]
+use core::intrinsics::{size_of, min_align_of};
 
 #[allow(improper_ctypes)]
 extern "C" {
@@ -147,6 +149,17 @@ unsafe fn exchange_free(ptr: *mut u8, old_size: usize, align: usize) {
     deallocate(ptr, old_size, align);
 }
 
+#[cfg(not(test))]
+#[lang = "box_free"]
+#[inline]
+unsafe fn box_free<T>(ptr: *mut T) {
+    let size = size_of::<T>();
+    // We do not allocate for Box<T> when T is ZST, so deallocation is also not necessary.
+    if size != 0 {
+        deallocate(ptr as *mut u8, size, min_align_of::<T>());
+    }
+}
+
 #[cfg(test)]
 mod tests {
     extern crate test;