diff options
| author | bors <bors@rust-lang.org> | 2016-02-06 01:24:22 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2016-02-06 01:24:22 +0000 |
| commit | 5147c1f2c04f62dceea5feaf6a2dcbebf5cd638f (patch) | |
| tree | 4d8cd52215cb214be361a4fe29e750597fdd6a61 /src/liballoc | |
| parent | 34af2de4096b3b1c5d3a5b70171c6e27822aaefb (diff) | |
| parent | caf62ef9846edfd41177b883181c5c045ca69859 (diff) | |
| download | rust-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.rs | 13 |
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; |
