diff --git a/src/libstd/vec.rs b/src/libstd/vec.rs index f607d1612ad81..4cc5c4f14ffdf 100644 --- a/src/libstd/vec.rs +++ b/src/libstd/vec.rs @@ -1201,8 +1201,6 @@ pub trait OwnedVector { fn shrink_to_fit(&mut self); fn push(&mut self, t: T); - unsafe fn push_fast(&mut self, t: T); - fn push_all_move(&mut self, rhs: ~[T]); fn pop(&mut self) -> T; fn pop_opt(&mut self) -> Option; @@ -1334,7 +1332,7 @@ impl OwnedVector for ~[T] { self.reserve_at_least(new_len); } - self.push_fast(t); + push_fast(self, t); } else { let repr: **Vec<()> = cast::transmute(&mut *self); let fill = (**repr).fill; @@ -1343,29 +1341,30 @@ impl OwnedVector for ~[T] { self.reserve_at_least(new_len); } - self.push_fast(t); + push_fast(self, t); } } - } - // This doesn't bother to make sure we have space. - #[inline] // really pretty please - unsafe fn push_fast(&mut self, t: T) { - if contains_managed::() { - let repr: **mut Box> = cast::transmute(self); - let fill = (**repr).data.fill; - (**repr).data.fill += sys::nonzero_size_of::(); - let p = to_unsafe_ptr(&((**repr).data.data)); - let p = ptr::offset(p, fill as int) as *mut T; - intrinsics::move_val_init(&mut(*p), t); - } else { - let repr: **mut Vec = cast::transmute(self); - let fill = (**repr).fill; - (**repr).fill += sys::nonzero_size_of::(); - let p = to_unsafe_ptr(&((**repr).data)); - let p = ptr::offset(p, fill as int) as *mut T; - intrinsics::move_val_init(&mut(*p), t); + // This doesn't bother to make sure we have space. + #[inline] // really pretty please + unsafe fn push_fast(this: &mut ~[T], t: T) { + if contains_managed::() { + let repr: **mut Box> = cast::transmute(this); + let fill = (**repr).data.fill; + (**repr).data.fill += sys::nonzero_size_of::(); + let p = to_unsafe_ptr(&((**repr).data.data)); + let p = ptr::offset(p, fill as int) as *mut T; + intrinsics::move_val_init(&mut(*p), t); + } else { + let repr: **mut Vec = cast::transmute(this); + let fill = (**repr).fill; + (**repr).fill += sys::nonzero_size_of::(); + let p = to_unsafe_ptr(&((**repr).data)); + let p = ptr::offset(p, fill as int) as *mut T; + intrinsics::move_val_init(&mut(*p), t); + } } + } /// Takes ownership of the vector `rhs`, moving all elements into