2014-03-20 01:51:08 +11:00
|
|
|
// Copyright 2014 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.
|
|
|
|
|
2014-07-12 00:50:57 -04:00
|
|
|
use std::fmt;
|
2014-03-20 01:51:08 +11:00
|
|
|
use std::default::Default;
|
2014-11-24 15:56:34 +11:00
|
|
|
use std::vec;
|
2014-03-20 01:51:08 +11:00
|
|
|
use serialize::{Encodable, Decodable, Encoder, Decoder};
|
|
|
|
|
2014-11-24 15:56:34 +11:00
|
|
|
/// A non-growable owned slice. This is a separate type to allow the
|
|
|
|
/// representation to change.
|
|
|
|
#[deriving(Hash, PartialEq, Eq, PartialOrd, Ord)]
|
2014-03-20 01:51:08 +11:00
|
|
|
pub struct OwnedSlice<T> {
|
2014-11-24 15:56:34 +11:00
|
|
|
data: Box<[T]>
|
2014-03-20 01:51:08 +11:00
|
|
|
}
|
|
|
|
|
2014-07-12 00:50:57 -04:00
|
|
|
impl<T:fmt::Show> fmt::Show for OwnedSlice<T> {
|
|
|
|
fn fmt(&self, fmt: &mut fmt::Formatter) -> fmt::Result {
|
2014-11-24 15:56:34 +11:00
|
|
|
self.data.fmt(fmt)
|
2014-03-20 01:51:08 +11:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<T> OwnedSlice<T> {
|
|
|
|
pub fn empty() -> OwnedSlice<T> {
|
2014-11-24 15:56:34 +11:00
|
|
|
OwnedSlice { data: box [] }
|
2014-03-20 01:51:08 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
#[inline(never)]
|
2014-11-24 15:56:34 +11:00
|
|
|
pub fn from_vec(v: Vec<T>) -> OwnedSlice<T> {
|
|
|
|
OwnedSlice { data: v.into_boxed_slice() }
|
2014-03-20 01:51:08 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
#[inline(never)]
|
|
|
|
pub fn into_vec(self) -> Vec<T> {
|
2014-11-24 15:56:34 +11:00
|
|
|
self.data.into_vec()
|
2014-03-20 01:51:08 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn as_slice<'a>(&'a self) -> &'a [T] {
|
2014-11-24 15:56:34 +11:00
|
|
|
&*self.data
|
2014-03-20 01:51:08 +11:00
|
|
|
}
|
|
|
|
|
2014-09-13 19:06:01 +03:00
|
|
|
pub fn move_iter(self) -> vec::MoveItems<T> {
|
2014-09-14 20:27:36 -07:00
|
|
|
self.into_vec().into_iter()
|
2014-09-13 19:06:01 +03:00
|
|
|
}
|
|
|
|
|
2014-03-20 01:51:08 +11:00
|
|
|
pub fn map<U>(&self, f: |&T| -> U) -> OwnedSlice<U> {
|
|
|
|
self.iter().map(f).collect()
|
|
|
|
}
|
2014-11-24 15:56:34 +11:00
|
|
|
}
|
2014-10-30 13:43:24 -07:00
|
|
|
|
2014-11-24 15:56:34 +11:00
|
|
|
impl<T> Deref<[T]> for OwnedSlice<T> {
|
|
|
|
fn deref(&self) -> &[T] {
|
|
|
|
self.as_slice()
|
|
|
|
}
|
2014-03-20 01:51:08 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
impl<T> Default for OwnedSlice<T> {
|
|
|
|
fn default() -> OwnedSlice<T> {
|
|
|
|
OwnedSlice::empty()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<T: Clone> Clone for OwnedSlice<T> {
|
|
|
|
fn clone(&self) -> OwnedSlice<T> {
|
2014-10-14 23:05:01 -07:00
|
|
|
OwnedSlice::from_vec(self.as_slice().to_vec())
|
2014-03-20 01:51:08 +11:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<T> FromIterator<T> for OwnedSlice<T> {
|
2014-11-06 09:32:37 -08:00
|
|
|
fn from_iter<I: Iterator<T>>(iter: I) -> OwnedSlice<T> {
|
2014-03-20 01:51:08 +11:00
|
|
|
OwnedSlice::from_vec(iter.collect())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-03-18 10:58:26 -07:00
|
|
|
impl<S: Encoder<E>, T: Encodable<S, E>, E> Encodable<S, E> for OwnedSlice<T> {
|
|
|
|
fn encode(&self, s: &mut S) -> Result<(), E> {
|
|
|
|
self.as_slice().encode(s)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<D: Decoder<E>, T: Decodable<D, E>, E> Decodable<D, E> for OwnedSlice<T> {
|
|
|
|
fn decode(d: &mut D) -> Result<OwnedSlice<T>, E> {
|
|
|
|
Ok(OwnedSlice::from_vec(match Decodable::decode(d) {
|
|
|
|
Ok(t) => t,
|
|
|
|
Err(e) => return Err(e)
|
|
|
|
}))
|
|
|
|
}
|
|
|
|
}
|