diff --git a/src/liballoc/vec.rs b/src/liballoc/vec.rs index 6e165ccb91998..e5abfdd52022a 100644 --- a/src/liballoc/vec.rs +++ b/src/liballoc/vec.rs @@ -1075,7 +1075,22 @@ impl Vec { pub fn retain(&mut self, mut f: F) where F: FnMut(&T) -> bool { - self.drain_filter(|x| !f(x)); + let len = self.len(); + let mut del = 0; + { + let v = &mut **self; + + for i in 0..len { + if !f(&v[i]) { + del += 1; + } else if del > 0 { + v.swap(i - del, i); + } + } + } + if del > 0 { + self.truncate(len - del); + } } /// Removes all but the first of consecutive elements in the vector that resolve to the same