// * The `raw` and `bytes` submodules.
// * Boilerplate trait implementations.
-use borrow::Borrow;
use cmp::Ordering::{self, Less, Equal, Greater};
use cmp;
use fmt;
fn as_ptr(&self) -> *const Self::Item;
#[stable(feature = "core", since = "1.6.0")]
- fn binary_search<Q: ?Sized>(&self, x: &Q) -> Result<usize, usize>
- where Self::Item: Borrow<Q>,
- Q: Ord;
+ fn binary_search(&self, x: &Self::Item) -> Result<usize, usize>
+ where Self::Item: Ord;
#[stable(feature = "core", since = "1.6.0")]
fn binary_search_by<'a, F>(&'a self, f: F) -> Result<usize, usize>
where F: FnMut(&'a Self::Item) -> Ordering;
#[stable(feature = "slice_binary_search_by_key", since = "1.10.0")]
- fn binary_search_by_key<'a, B, F, Q: ?Sized>(&'a self, b: &Q, f: F) -> Result<usize, usize>
+ fn binary_search_by_key<'a, B, F>(&'a self, b: &B, f: F) -> Result<usize, usize>
where F: FnMut(&'a Self::Item) -> B,
- B: Borrow<Q>,
- Q: Ord;
+ B: Ord;
#[stable(feature = "core", since = "1.6.0")]
fn len(&self) -> usize;
#[stable(feature = "copy_from_slice", since = "1.9.0")]
fn copy_from_slice(&mut self, src: &[Self::Item]) where Self::Item: Copy;
+ #[unstable(feature = "swap_with_slice", issue = "44030")]
+ fn swap_with_slice(&mut self, src: &mut [Self::Item]);
+
#[stable(feature = "sort_unstable", since = "1.20.0")]
fn sort_unstable(&mut self)
where Self::Item: Ord;
m >= n && needle == &self[m-n..]
}
- fn binary_search<Q: ?Sized>(&self, x: &Q) -> Result<usize, usize>
- where T: Borrow<Q>,
- Q: Ord
+ fn binary_search(&self, x: &T) -> Result<usize, usize>
+ where T: Ord
{
- self.binary_search_by(|p| p.borrow().cmp(x))
+ self.binary_search_by(|p| p.cmp(x))
}
fn rotate(&mut self, mid: usize) {
}
#[inline]
- fn binary_search_by_key<'a, B, F, Q: ?Sized>(&'a self, b: &Q, mut f: F) -> Result<usize, usize>
+ fn swap_with_slice(&mut self, src: &mut [T]) {
+ assert!(self.len() == src.len(),
+ "destination and source slices have different lengths");
+ unsafe {
+ ptr::swap_nonoverlapping(
+ self.as_mut_ptr(), src.as_mut_ptr(), self.len());
+ }
+ }
+
+ #[inline]
+ fn binary_search_by_key<'a, B, F>(&'a self, b: &B, mut f: F) -> Result<usize, usize>
where F: FnMut(&'a Self::Item) -> B,
- B: Borrow<Q>,
- Q: Ord
+ B: Ord
{
- self.binary_search_by(|k| f(k).borrow().cmp(b))
+ self.binary_search_by(|k| f(k).cmp(b))
}
#[inline]