From 2ff84124f0d39b20f49ce04f71d31322cdf1a327 Mon Sep 17 00:00:00 2001 From: blake2-ppc Date: Tue, 30 Jul 2013 00:31:44 +0200 Subject: std: Remove RandomAccessIterator impl for VecMutIterator The RandomAccessIterator implementation is not sound for the mutable vec iterator, and makes it easy to duplicate &mut element pointers. --- src/libstd/vec.rs | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) (limited to 'src/libstd') diff --git a/src/libstd/vec.rs b/src/libstd/vec.rs index fdfe357ae51..ca752490faa 100644 --- a/src/libstd/vec.rs +++ b/src/libstd/vec.rs @@ -2106,7 +2106,8 @@ macro_rules! iterator { #[inline] fn size_hint(&self) -> (uint, Option) { - let exact = self.indexable(); + let diff = (self.end as uint) - (self.ptr as uint); + let exact = diff / sys::nonzero_size_of::(); (exact, Some(exact)) } } @@ -2139,8 +2140,8 @@ macro_rules! random_access_iterator { impl<'self, T> RandomAccessIterator<$elem> for $name<'self, T> { #[inline] fn indexable(&self) -> uint { - let diff = (self.end as uint) - (self.ptr as uint); - diff / sys::nonzero_size_of::() + let (exact, _) = self.size_hint(); + exact } fn idx(&self, index: uint) -> Option<$elem> { @@ -2181,7 +2182,6 @@ pub struct VecMutIterator<'self, T> { } iterator!{impl VecMutIterator -> &'self mut T} double_ended_iterator!{impl VecMutIterator -> &'self mut T} -random_access_iterator!{impl VecMutIterator -> &'self mut T} pub type MutRevIterator<'self, T> = Invert>; /// An iterator that moves out of a vector. -- cgit 1.4.1-3-g733a5