Conversions between CStr/OsStr/Path and boxes.
This commit is contained in:
parent
2425b22774
commit
963843b1b3
8 changed files with 192 additions and 1 deletions
|
@ -1194,6 +1194,28 @@ impl PathBuf {
|
|||
pub fn into_os_string(self) -> OsString {
|
||||
self.inner
|
||||
}
|
||||
|
||||
/// Converts this `PathBuf` into a boxed `Path`.
|
||||
#[unstable(feature = "into_boxed_path", issue = "0")]
|
||||
pub fn into_boxed_path(self) -> Box<Path> {
|
||||
unsafe { mem::transmute(self.inner.into_boxed_os_str()) }
|
||||
}
|
||||
}
|
||||
|
||||
#[stable(feature = "box_from_path", since = "1.17.0")]
|
||||
impl<'a> From<&'a Path> for Box<Path> {
|
||||
fn from(path: &'a Path) -> Box<Path> {
|
||||
let boxed: Box<OsStr> = path.inner.into();
|
||||
unsafe { mem::transmute(boxed) }
|
||||
}
|
||||
}
|
||||
|
||||
#[stable(feature = "box_default_extra", since = "1.17.0")]
|
||||
impl Default for Box<Path> {
|
||||
fn default() -> Box<Path> {
|
||||
let boxed: Box<OsStr> = Default::default();
|
||||
unsafe { mem::transmute(boxed) }
|
||||
}
|
||||
}
|
||||
|
||||
#[stable(feature = "rust1", since = "1.0.0")]
|
||||
|
@ -3676,4 +3698,22 @@ mod tests {
|
|||
let actual = format!("{:?}", iter);
|
||||
assert_eq!(expected, actual);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn into_boxed() {
|
||||
let orig: &str = "some/sort/of/path";
|
||||
let path = Path::new(orig);
|
||||
let path_buf = path.to_owned();
|
||||
let box1: Box<Path> = Box::from(path);
|
||||
let box2 = path_buf.into_boxed_path();
|
||||
assert_eq!(path, &*box1);
|
||||
assert_eq!(box1, box2);
|
||||
assert_eq!(&*box2, path);
|
||||
}
|
||||
|
||||
#[test]
|
||||
fn boxed_default() {
|
||||
let boxed = <Box<Path>>::default();
|
||||
assert!(boxed.as_os_str().is_empty());
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue