diff options
| author | Corey Farwell <coreyf@rwell.org> | 2016-02-12 12:21:57 -0500 |
|---|---|---|
| committer | Corey Farwell <coreyf@rwell.org> | 2016-02-20 11:37:58 -0500 |
| commit | 2338d7419743f876135f723d1823dde16bdb7fdf (patch) | |
| tree | e76b80e4f9fc0bfe22862146cbb0078aa45e6e10 /src/libstd/sys | |
| parent | 4d3eebff9dc9474f56cdba810edde324130fbc61 (diff) | |
| download | rust-2338d7419743f876135f723d1823dde16bdb7fdf.tar.gz rust-2338d7419743f876135f723d1823dde16bdb7fdf.zip | |
Add Capacity/length methods for OsString.
https://github.com/rust-lang/rust/issues/29453
Diffstat (limited to 'src/libstd/sys')
| -rw-r--r-- | src/libstd/sys/common/wtf8.rs | 14 | ||||
| -rw-r--r-- | src/libstd/sys/unix/os_str.rs | 41 | ||||
| -rw-r--r-- | src/libstd/sys/windows/os_str.rs | 35 |
3 files changed, 90 insertions, 0 deletions
diff --git a/src/libstd/sys/common/wtf8.rs b/src/libstd/sys/common/wtf8.rs index bc997af3a27..68ba2fe20b4 100644 --- a/src/libstd/sys/common/wtf8.rs +++ b/src/libstd/sys/common/wtf8.rs @@ -178,6 +178,10 @@ impl Wtf8Buf { Wtf8Buf { bytes: <[_]>::to_vec(str.as_bytes()) } } + pub fn clear(&mut self) { + self.bytes.clear() + } + /// Creates a WTF-8 string from a potentially ill-formed UTF-16 slice of 16-bit code units. /// /// This is lossless: calling `.encode_wide()` on the resulting string @@ -234,6 +238,11 @@ impl Wtf8Buf { self.bytes.reserve(additional) } + #[inline] + pub fn reserve_exact(&mut self, additional: usize) { + self.bytes.reserve_exact(additional) + } + /// Returns the number of bytes that this string buffer can hold without reallocating. #[inline] pub fn capacity(&self) -> usize { @@ -443,6 +452,11 @@ impl Wtf8 { self.bytes.len() } + #[inline] + pub fn is_empty(&self) -> bool { + self.bytes.is_empty() + } + /// Returns the code point at `position` if it is in the ASCII range, /// or `b'\xFF' otherwise. /// diff --git a/src/libstd/sys/unix/os_str.rs b/src/libstd/sys/unix/os_str.rs index 0524df218a1..d5eea5d1f3b 100644 --- a/src/libstd/sys/unix/os_str.rs +++ b/src/libstd/sys/unix/os_str.rs @@ -17,6 +17,7 @@ use vec::Vec; use str; use string::String; use mem; +use sys_common::{AsInner, IntoInner}; #[derive(Clone, Hash)] pub struct Buf { @@ -39,11 +40,51 @@ impl Debug for Buf { } } +impl IntoInner<Vec<u8>> for Buf { + fn into_inner(self) -> Vec<u8> { + self.inner + } +} + +impl AsInner<[u8]> for Buf { + fn as_inner(&self) -> &[u8] { + &self.inner + } +} + + impl Buf { pub fn from_string(s: String) -> Buf { Buf { inner: s.into_bytes() } } + #[inline] + pub fn with_capacity(capacity: usize) -> Buf { + Buf { + inner: Vec::with_capacity(capacity) + } + } + + #[inline] + pub fn clear(&mut self) { + self.inner.clear() + } + + #[inline] + pub fn capacity(&self) -> usize { + self.inner.capacity() + } + + #[inline] + pub fn reserve(&mut self, additional: usize) { + self.inner.reserve(additional) + } + + #[inline] + pub fn reserve_exact(&mut self, additional: usize) { + self.inner.reserve_exact(additional) + } + pub fn as_slice(&self) -> &Slice { unsafe { mem::transmute(&*self.inner) } } diff --git a/src/libstd/sys/windows/os_str.rs b/src/libstd/sys/windows/os_str.rs index 91905ae7489..26767a1349e 100644 --- a/src/libstd/sys/windows/os_str.rs +++ b/src/libstd/sys/windows/os_str.rs @@ -18,12 +18,25 @@ use string::String; use result::Result; use option::Option; use mem; +use sys_common::{AsInner, IntoInner}; #[derive(Clone, Hash)] pub struct Buf { pub inner: Wtf8Buf } +impl IntoInner<Wtf8Buf> for Buf { + fn into_inner(self) -> Wtf8Buf { + self.inner + } +} + +impl AsInner<Wtf8> for Buf { + fn as_inner(&self) -> &Wtf8 { + &self.inner + } +} + impl Debug for Buf { fn fmt(&self, formatter: &mut fmt::Formatter) -> Result<(), fmt::Error> { self.as_slice().fmt(formatter) @@ -41,6 +54,20 @@ impl Debug for Slice { } impl Buf { + pub fn with_capacity(capacity: usize) -> Buf { + Buf { + inner: Wtf8Buf::with_capacity(capacity) + } + } + + pub fn clear(&mut self) { + self.inner.clear() + } + + pub fn capacity(&self) -> usize { + self.inner.capacity() + } + pub fn from_string(s: String) -> Buf { Buf { inner: Wtf8Buf::from_string(s) } } @@ -56,6 +83,14 @@ impl Buf { pub fn push_slice(&mut self, s: &Slice) { self.inner.push_wtf8(&s.inner) } + + pub fn reserve(&mut self, additional: usize) { + self.inner.reserve(additional) + } + + pub fn reserve_exact(&mut self, additional: usize) { + self.inner.reserve_exact(additional) + } } impl Slice { |
