diff options
| author | Niko Matsakis <niko@alum.mit.edu> | 2016-02-25 16:56:11 -0500 |
|---|---|---|
| committer | Niko Matsakis <niko@alum.mit.edu> | 2016-02-25 16:56:11 -0500 |
| commit | b7f53b8aa6bafe0642efda7e387507fdb6be56df (patch) | |
| tree | 5b2622b6e9c833a56f831766deef1ac8d35ca55c | |
| parent | 356bf529eedaea523b4266057b2ce8a13435b737 (diff) | |
| download | rust-b7f53b8aa6bafe0642efda7e387507fdb6be56df.tar.gz rust-b7f53b8aa6bafe0642efda7e387507fdb6be56df.zip | |
fix drop of fat ptrs
| -rw-r--r-- | src/librustc_trans/trans/mir/operand.rs | 3 | ||||
| -rw-r--r-- | src/test/run-pass/mir_fat_ptr_drop.rs | 39 |
2 files changed, 40 insertions, 2 deletions
diff --git a/src/librustc_trans/trans/mir/operand.rs b/src/librustc_trans/trans/mir/operand.rs index 8343322d29d..5db5fc82c1f 100644 --- a/src/librustc_trans/trans/mir/operand.rs +++ b/src/librustc_trans/trans/mir/operand.rs @@ -245,8 +245,7 @@ impl<'bcx, 'tcx> MirContext<'bcx, 'tcx> { } let lvalue = self.trans_lvalue(bcx, lvalue); let ty = lvalue.ty.to_ty(bcx.tcx()); - if !glue::type_needs_drop(bcx.tcx(), ty) || - common::type_is_fat_ptr(bcx.tcx(), ty) { + if !glue::type_needs_drop(bcx.tcx(), ty) { return } else { drop::drop_fill(bcx, lvalue.llval, ty); diff --git a/src/test/run-pass/mir_fat_ptr_drop.rs b/src/test/run-pass/mir_fat_ptr_drop.rs new file mode 100644 index 00000000000..3f79be04793 --- /dev/null +++ b/src/test/run-pass/mir_fat_ptr_drop.rs @@ -0,0 +1,39 @@ +// Copyright 2015 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. + +// test that ordinary fat pointer operations work. + +#![feature(braced_empty_structs)] +#![feature(rustc_attrs)] + +use std::sync::atomic; +use std::sync::atomic::Ordering::SeqCst; + +static COUNTER: atomic::AtomicUsize = atomic::ATOMIC_USIZE_INIT; + +struct DropMe { +} + +impl Drop for DropMe { + fn drop(&mut self) { + COUNTER.fetch_add(1, SeqCst); + } +} + +#[rustc_mir] +fn fat_ptr_move_then_drop(a: Box<[DropMe]>) { + let b = a; +} + +fn main() { + let a: Box<[DropMe]> = Box::new([DropMe { }]); + fat_ptr_move_then_drop(a); + assert_eq!(COUNTER.load(SeqCst), 1); +} |
