Rollup merge of #105002 - zertosh:acp-140, r=dtolnay
Add `PathBuf::as_mut_os_string` and `Path::as_mut_os_str` Implements rust-lang/libs-team#140 (tracking issue #105021).
This commit is contained in:
commit
804fa66a02
@ -1463,6 +1463,30 @@ fn _set_extension(&mut self, extension: &OsStr) -> bool {
|
|||||||
true
|
true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Yields a mutable reference to the underlying [`OsString`] instance.
|
||||||
|
///
|
||||||
|
/// # Examples
|
||||||
|
///
|
||||||
|
/// ```
|
||||||
|
/// #![feature(path_as_mut_os_str)]
|
||||||
|
/// use std::path::{Path, PathBuf};
|
||||||
|
///
|
||||||
|
/// let mut path = PathBuf::from("/foo");
|
||||||
|
///
|
||||||
|
/// path.push("bar");
|
||||||
|
/// assert_eq!(path, Path::new("/foo/bar"));
|
||||||
|
///
|
||||||
|
/// // OsString's `push` does not add a separator.
|
||||||
|
/// path.as_mut_os_string().push("baz");
|
||||||
|
/// assert_eq!(path, Path::new("/foo/barbaz"));
|
||||||
|
/// ```
|
||||||
|
#[unstable(feature = "path_as_mut_os_str", issue = "105021")]
|
||||||
|
#[must_use]
|
||||||
|
#[inline]
|
||||||
|
pub fn as_mut_os_string(&mut self) -> &mut OsString {
|
||||||
|
&mut self.inner
|
||||||
|
}
|
||||||
|
|
||||||
/// Consumes the `PathBuf`, yielding its internal [`OsString`] storage.
|
/// Consumes the `PathBuf`, yielding its internal [`OsString`] storage.
|
||||||
///
|
///
|
||||||
/// # Examples
|
/// # Examples
|
||||||
@ -1993,6 +2017,28 @@ pub fn as_os_str(&self) -> &OsStr {
|
|||||||
&self.inner
|
&self.inner
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Yields a mutable reference to the underlying [`OsStr`] slice.
|
||||||
|
///
|
||||||
|
/// # Examples
|
||||||
|
///
|
||||||
|
/// ```
|
||||||
|
/// #![feature(path_as_mut_os_str)]
|
||||||
|
/// use std::path::{Path, PathBuf};
|
||||||
|
///
|
||||||
|
/// let mut path = PathBuf::from("/Foo.TXT").into_boxed_path();
|
||||||
|
///
|
||||||
|
/// assert_ne!(&*path, Path::new("/foo.txt"));
|
||||||
|
///
|
||||||
|
/// path.as_mut_os_str().make_ascii_lowercase();
|
||||||
|
/// assert_eq!(&*path, Path::new("/foo.txt"));
|
||||||
|
/// ```
|
||||||
|
#[unstable(feature = "path_as_mut_os_str", issue = "105021")]
|
||||||
|
#[must_use]
|
||||||
|
#[inline]
|
||||||
|
pub fn as_mut_os_str(&mut self) -> &mut OsStr {
|
||||||
|
&mut self.inner
|
||||||
|
}
|
||||||
|
|
||||||
/// Yields a [`&str`] slice if the `Path` is valid unicode.
|
/// Yields a [`&str`] slice if the `Path` is valid unicode.
|
||||||
///
|
///
|
||||||
/// This conversion may entail doing a check for UTF-8 validity.
|
/// This conversion may entail doing a check for UTF-8 validity.
|
||||||
|
Loading…
Reference in New Issue
Block a user