pub struct OsString { /* private fields */ }Expand description
A type that can represent owned, mutable platform-native strings, but is cheaply inter-convertible with Rust strings.
The need for this type arises from the fact that:
-
On Unix systems, strings are often arbitrary sequences of non-zero bytes, in many cases interpreted as UTF-8.
-
On Windows, strings are often arbitrary sequences of non-zero 16-bit values, interpreted as UTF-16 when it is valid to do so.
-
In Rust, strings are always valid UTF-8, which may contain zeros.
OsString and OsStr bridge this gap by simultaneously representing Rust
and platform-native string values, and in particular allowing a Rust string
to be converted into an “OS” string with no cost if possible. A consequence
of this is that OsString instances are not NUL terminated; in order
to pass to e.g., Unix system call, you should create a CStr.
OsString is to &OsStr as String is to &str: the former
in each pair are owned strings; the latter are borrowed
references.
Note, OsString and OsStr internally do not necessarily hold strings in
the form native to the platform; While on Unix, strings are stored as a
sequence of 8-bit values, on Windows, where strings are 16-bit value based
as just discussed, strings are also actually stored as a sequence of 8-bit
values, encoded in a less-strict variant of UTF-8. This is useful to
understand when handling capacity and length values.
Creating an OsString
From a Rust string: OsString implements
From<String>, so you can use my_string.into() to
create an OsString from a normal Rust string.
From slices: Just like you can start with an empty Rust
String and then String::push_str some &str
sub-string slices into it, you can create an empty OsString with
the OsString::new method and then push string slices into it with the
OsString::push method.
Extracting a borrowed reference to the whole OS string
You can use the OsString::as_os_str method to get an &OsStr from
an OsString; this is effectively a borrowed reference to the
whole string.
Conversions
See the module’s toplevel documentation about conversions for a discussion on
the traits which OsString implements for conversions from/to native representations.
Implementations
impl OsString
source
impl OsString
sourcepub fn into_string(self) -> Result<String, OsString>
source
pub fn into_string(self) -> Result<String, OsString>
sourcepub fn with_capacity(capacity: usize) -> OsString
1.9.0 · source
pub fn with_capacity(capacity: usize) -> OsString
1.9.0 · sourceCreates a new OsString with the given capacity.
The string will be able to hold exactly capacity length units of other
OS strings without reallocating. If capacity is 0, the string will not
allocate.
See main OsString documentation information about encoding.
Examples
use std::ffi::OsString;
let mut os_string = OsString::with_capacity(10);
let capacity = os_string.capacity();
// This push is done without reallocating
os_string.push("foo");
assert_eq!(capacity, os_string.capacity());Runpub fn try_reserve(&mut self, additional: usize) -> Result<(), TryReserveError>
source
pub fn try_reserve(&mut self, additional: usize) -> Result<(), TryReserveError>
sourceTries to reserve capacity for at least additional more length units
in the given OsString. The string may reserve more space to avoid
frequent reallocations. After calling try_reserve, capacity will be
greater than or equal to self.len() + additional. Does nothing if
capacity is already sufficient.
Errors
If the capacity overflows, or the allocator reports a failure, then an error is returned.
Examples
#![feature(try_reserve_2)]
use std::ffi::{OsStr, OsString};
use std::collections::TryReserveError;
fn process_data(data: &str) -> Result<OsString, TryReserveError> {
let mut s = OsString::new();
// Pre-reserve the memory, exiting if we can't
s.try_reserve(OsStr::new(data).len())?;
// Now we know this can't OOM in the middle of our complex work
s.push(data);
Ok(s)
}Runpub fn reserve_exact(&mut self, additional: usize)
1.9.0 · source
pub fn reserve_exact(&mut self, additional: usize)
1.9.0 · sourceReserves the minimum capacity for exactly additional more capacity to
be inserted in the given OsString. Does nothing if the capacity is
already sufficient.
Note that the allocator may give the collection more space than it
requests. Therefore, capacity can not be relied upon to be precisely
minimal. Prefer reserve if future insertions are expected.
Examples
use std::ffi::OsString;
let mut s = OsString::new();
s.reserve_exact(10);
assert!(s.capacity() >= 10);Runpub fn try_reserve_exact(
&mut self,
additional: usize
) -> Result<(), TryReserveError>
source
pub fn try_reserve_exact(
&mut self,
additional: usize
) -> Result<(), TryReserveError>
sourceTries to reserve the minimum capacity for exactly additional
more length units in the given OsString. After calling
try_reserve_exact, capacity will be greater than or equal to
self.len() + additional if it returns Ok(()).
Does nothing if the capacity is already sufficient.
Note that the allocator may give the OsString more space than it
requests. Therefore, capacity can not be relied upon to be precisely
minimal. Prefer try_reserve if future insertions are expected.
Errors
If the capacity overflows, or the allocator reports a failure, then an error is returned.
Examples
#![feature(try_reserve_2)]
use std::ffi::{OsStr, OsString};
use std::collections::TryReserveError;
fn process_data(data: &str) -> Result<OsString, TryReserveError> {
let mut s = OsString::new();
// Pre-reserve the memory, exiting if we can't
s.try_reserve_exact(OsStr::new(data).len())?;
// Now we know this can't OOM in the middle of our complex work
s.push(data);
Ok(s)
}Runpub fn shrink_to_fit(&mut self)
1.19.0 · source
pub fn shrink_to_fit(&mut self)
1.19.0 · sourcepub fn shrink_to(&mut self, min_capacity: usize)
1.56.0 · source
pub fn shrink_to(&mut self, min_capacity: usize)
1.56.0 · sourceShrinks the capacity of the OsString with a lower bound.
The capacity will remain at least as large as both the length and the supplied value.
If the current capacity is less than the lower limit, this is a no-op.
Examples
use std::ffi::OsString;
let mut s = OsString::from("foo");
s.reserve(100);
assert!(s.capacity() >= 100);
s.shrink_to(10);
assert!(s.capacity() >= 10);
s.shrink_to(0);
assert!(s.capacity() >= 3);Runpub fn into_boxed_os_str(self) -> Box<OsStr>ⓘNotable traits for Box<I, A>impl<I, A> Iterator for Box<I, A> where
I: Iterator + ?Sized,
A: Allocator, type Item = <I as Iterator>::Item;impl<F, A> Future for Box<F, A> where
F: Future + Unpin + ?Sized,
A: Allocator + 'static, type Output = <F as Future>::Output;impl<R: Read + ?Sized> Read for Box<R>impl<W: Write + ?Sized> Write for Box<W>
1.20.0 · source
pub fn into_boxed_os_str(self) -> Box<OsStr>ⓘNotable traits for Box<I, A>impl<I, A> Iterator for Box<I, A> where
I: Iterator + ?Sized,
A: Allocator, type Item = <I as Iterator>::Item;impl<F, A> Future for Box<F, A> where
F: Future + Unpin + ?Sized,
A: Allocator + 'static, type Output = <F as Future>::Output;impl<R: Read + ?Sized> Read for Box<R>impl<W: Write + ?Sized> Write for Box<W>
1.20.0 · sourceI: Iterator + ?Sized,
A: Allocator, type Item = <I as Iterator>::Item;impl<F, A> Future for Box<F, A> where
F: Future + Unpin + ?Sized,
A: Allocator + 'static, type Output = <F as Future>::Output;impl<R: Read + ?Sized> Read for Box<R>impl<W: Write + ?Sized> Write for Box<W>
Methods from Deref<Target = OsStr>
pub fn to_string_lossy(&self) -> Cow<'_, str>
source
pub fn to_string_lossy(&self) -> Cow<'_, str>
sourceConverts an OsStr to a Cow<str>.
Any non-Unicode sequences are replaced with
U+FFFD REPLACEMENT CHARACTER.
Examples
Calling to_string_lossy on an OsStr with invalid unicode:
// Note, due to differences in how Unix and Windows represent strings,
// we are forced to complicate this example, setting up example `OsStr`s
// with different source data and via different platform extensions.
// Understand that in reality you could end up with such example invalid
// sequences simply through collecting user command line arguments, for
// example.
#[cfg(unix)] {
use std::ffi::OsStr;
use std::os::unix::ffi::OsStrExt;
// Here, the values 0x66 and 0x6f correspond to 'f' and 'o'
// respectively. The value 0x80 is a lone continuation byte, invalid
// in a UTF-8 sequence.
let source = [0x66, 0x6f, 0x80, 0x6f];
let os_str = OsStr::from_bytes(&source[..]);
assert_eq!(os_str.to_string_lossy(), "fo�o");
}
#[cfg(windows)] {
use std::ffi::OsString;
use std::os::windows::prelude::*;
// Here the values 0x0066 and 0x006f correspond to 'f' and 'o'
// respectively. The value 0xD800 is a lone surrogate half, invalid
// in a UTF-16 sequence.
let source = [0x0066, 0x006f, 0xD800, 0x006f];
let os_string = OsString::from_wide(&source[..]);
let os_str = os_string.as_os_str();
assert_eq!(os_str.to_string_lossy(), "fo�o");
}Runpub fn to_os_string(&self) -> OsString
source
pub fn to_os_string(&self) -> OsString
sourcepub fn len(&self) -> usize
1.9.0 · source
pub fn len(&self) -> usize
1.9.0 · sourceReturns the length of this OsStr.
Note that this does not return the number of bytes in the string in OS string form.
The length returned is that of the underlying storage used by OsStr.
As discussed in the OsString introduction, OsString and OsStr
store strings in a form best suited for cheap inter-conversion between
native-platform and Rust string forms, which may differ significantly
from both of them, including in storage size and encoding.
This number is simply useful for passing to other methods, like
OsString::with_capacity to avoid reallocations.
Examples
use std::ffi::OsStr;
let os_str = OsStr::new("");
assert_eq!(os_str.len(), 0);
let os_str = OsStr::new("foo");
assert_eq!(os_str.len(), 3);Runpub fn make_ascii_lowercase(&mut self)
1.53.0 · source
pub fn make_ascii_lowercase(&mut self)
1.53.0 · sourceConverts this string to its ASCII lower case equivalent in-place.
ASCII letters ‘A’ to ‘Z’ are mapped to ‘a’ to ‘z’, but non-ASCII letters are unchanged.
To return a new lowercased value without modifying the existing one, use
OsStr::to_ascii_lowercase.
Examples
use std::ffi::OsString;
let mut s = OsString::from("GRÜßE, JÜRGEN ❤");
s.make_ascii_lowercase();
assert_eq!("grÜße, jÜrgen ❤", s);Runpub fn make_ascii_uppercase(&mut self)
1.53.0 · source
pub fn make_ascii_uppercase(&mut self)
1.53.0 · sourceConverts this string to its ASCII upper case equivalent in-place.
ASCII letters ‘a’ to ‘z’ are mapped to ‘A’ to ‘Z’, but non-ASCII letters are unchanged.
To return a new uppercased value without modifying the existing one, use
OsStr::to_ascii_uppercase.
Examples
use std::ffi::OsString;
let mut s = OsString::from("Grüße, Jürgen ❤");
s.make_ascii_uppercase();
assert_eq!("GRüßE, JüRGEN ❤", s);Runpub fn to_ascii_lowercase(&self) -> OsString
1.53.0 · source
pub fn to_ascii_lowercase(&self) -> OsString
1.53.0 · sourceReturns a copy of this string where each character is mapped to its ASCII lower case equivalent.
ASCII letters ‘A’ to ‘Z’ are mapped to ‘a’ to ‘z’, but non-ASCII letters are unchanged.
To lowercase the value in-place, use OsStr::make_ascii_lowercase.
Examples
use std::ffi::OsString;
let s = OsString::from("Grüße, Jürgen ❤");
assert_eq!("grüße, jürgen ❤", s.to_ascii_lowercase());Runpub fn to_ascii_uppercase(&self) -> OsString
1.53.0 · source
pub fn to_ascii_uppercase(&self) -> OsString
1.53.0 · sourceReturns a copy of this string where each character is mapped to its ASCII upper case equivalent.
ASCII letters ‘a’ to ‘z’ are mapped to ‘A’ to ‘Z’, but non-ASCII letters are unchanged.
To uppercase the value in-place, use OsStr::make_ascii_uppercase.
Examples
use std::ffi::OsString;
let s = OsString::from("Grüße, Jürgen ❤");
assert_eq!("GRüßE, JüRGEN ❤", s.to_ascii_uppercase());Runpub fn eq_ignore_ascii_case<S: AsRef<OsStr>>(&self, other: S) -> bool
1.53.0 · source
pub fn eq_ignore_ascii_case<S: AsRef<OsStr>>(&self, other: S) -> bool
1.53.0 · sourceChecks that two strings are an ASCII case-insensitive match.
Same as to_ascii_lowercase(a) == to_ascii_lowercase(b),
but without allocating and copying temporaries.
Examples
use std::ffi::OsString;
assert!(OsString::from("Ferris").eq_ignore_ascii_case("FERRIS"));
assert!(OsString::from("Ferrös").eq_ignore_ascii_case("FERRöS"));
assert!(!OsString::from("Ferrös").eq_ignore_ascii_case("FERRÖS"));RunTrait Implementations
impl<'a> Extend<&'a OsStr> for OsString
1.52.0 · source
impl<'a> Extend<&'a OsStr> for OsString
1.52.0 · sourcefn extend<T: IntoIterator<Item = &'a OsStr>>(&mut self, iter: T)
source
fn extend<T: IntoIterator<Item = &'a OsStr>>(&mut self, iter: T)
sourceExtends a collection with the contents of an iterator. Read more
fn extend_reserve(&mut self, additional: usize)
source
fn extend_reserve(&mut self, additional: usize)
sourceReserves capacity in a collection for the given number of additional elements. Read more
impl<'a> Extend<Cow<'a, OsStr>> for OsString
1.52.0 · source
impl<'a> Extend<Cow<'a, OsStr>> for OsString
1.52.0 · sourcefn extend<T: IntoIterator<Item = Cow<'a, OsStr>>>(&mut self, iter: T)
source
fn extend<T: IntoIterator<Item = Cow<'a, OsStr>>>(&mut self, iter: T)
sourceExtends a collection with the contents of an iterator. Read more
fn extend_reserve(&mut self, additional: usize)
source
fn extend_reserve(&mut self, additional: usize)
sourceReserves capacity in a collection for the given number of additional elements. Read more
impl Extend<OsString> for OsString
1.52.0 · source
impl Extend<OsString> for OsString
1.52.0 · sourcefn extend<T: IntoIterator<Item = OsString>>(&mut self, iter: T)
source
fn extend<T: IntoIterator<Item = OsString>>(&mut self, iter: T)
sourceExtends a collection with the contents of an iterator. Read more
fn extend_reserve(&mut self, additional: usize)
source
fn extend_reserve(&mut self, additional: usize)
sourceReserves capacity in a collection for the given number of additional elements. Read more
impl From<OsString> for Box<OsStr>
1.20.0 · source
impl From<OsString> for Box<OsStr>
1.20.0 · sourcefn from(s: OsString) -> Box<OsStr>ⓘNotable traits for Box<I, A>impl<I, A> Iterator for Box<I, A> where
I: Iterator + ?Sized,
A: Allocator, type Item = <I as Iterator>::Item;impl<F, A> Future for Box<F, A> where
F: Future + Unpin + ?Sized,
A: Allocator + 'static, type Output = <F as Future>::Output;impl<R: Read + ?Sized> Read for Box<R>impl<W: Write + ?Sized> Write for Box<W>
source
fn from(s: OsString) -> Box<OsStr>ⓘNotable traits for Box<I, A>impl<I, A> Iterator for Box<I, A> where
I: Iterator + ?Sized,
A: Allocator, type Item = <I as Iterator>::Item;impl<F, A> Future for Box<F, A> where
F: Future + Unpin + ?Sized,
A: Allocator + 'static, type Output = <F as Future>::Output;impl<R: Read + ?Sized> Read for Box<R>impl<W: Write + ?Sized> Write for Box<W>
sourceI: Iterator + ?Sized,
A: Allocator, type Item = <I as Iterator>::Item;impl<F, A> Future for Box<F, A> where
F: Future + Unpin + ?Sized,
A: Allocator + 'static, type Output = <F as Future>::Output;impl<R: Read + ?Sized> Read for Box<R>impl<W: Write + ?Sized> Write for Box<W>
impl<'a> FromIterator<&'a OsStr> for OsString
1.52.0 · source
impl<'a> FromIterator<&'a OsStr> for OsString
1.52.0 · sourcefn from_iter<I: IntoIterator<Item = &'a OsStr>>(iter: I) -> Self
source
fn from_iter<I: IntoIterator<Item = &'a OsStr>>(iter: I) -> Self
sourceCreates a value from an iterator. Read more
impl<'a> FromIterator<Cow<'a, OsStr>> for OsString
1.52.0 · source
impl<'a> FromIterator<Cow<'a, OsStr>> for OsString
1.52.0 · sourceimpl FromIterator<OsString> for OsString
1.52.0 · source
impl FromIterator<OsString> for OsString
1.52.0 · sourcefn from_iter<I: IntoIterator<Item = OsString>>(iter: I) -> Self
source
fn from_iter<I: IntoIterator<Item = OsString>>(iter: I) -> Self
sourceCreates a value from an iterator. Read more
impl Ord for OsString
source
impl Ord for OsString
sourceimpl OsStringExt for OsString
source Available on Unix only.
impl OsStringExt for OsString
sourceimpl OsStringExt for OsString
source Available on WASI only.
impl OsStringExt for OsString
sourceimpl OsStringExt for OsString
source Available on Windows only.
impl OsStringExt for OsString
sourceimpl<'a, 'b> PartialOrd<&'a OsStr> for OsString
1.8.0 · source
impl<'a, 'b> PartialOrd<&'a OsStr> for OsString
1.8.0 · sourcefn partial_cmp(&self, other: &&'a OsStr) -> Option<Ordering>
source
fn partial_cmp(&self, other: &&'a OsStr) -> Option<Ordering>
sourceThis method returns an ordering between self and other values if one exists. Read more
fn lt(&self, other: &Rhs) -> bool
source
fn lt(&self, other: &Rhs) -> bool
sourceThis method tests less than (for self and other) and is used by the < operator. Read more
fn le(&self, other: &Rhs) -> bool
source
fn le(&self, other: &Rhs) -> bool
sourceThis method tests less than or equal to (for self and other) and is used by the <=
operator. Read more
impl<'a, 'b> PartialOrd<&'a Path> for OsString
1.8.0 · source
impl<'a, 'b> PartialOrd<&'a Path> for OsString
1.8.0 · sourcefn partial_cmp(&self, other: &&'a Path) -> Option<Ordering>
source
fn partial_cmp(&self, other: &&'a Path) -> Option<Ordering>
sourceThis method returns an ordering between self and other values if one exists. Read more
fn lt(&self, other: &Rhs) -> bool
source
fn lt(&self, other: &Rhs) -> bool
sourceThis method tests less than (for self and other) and is used by the < operator. Read more
fn le(&self, other: &Rhs) -> bool
source
fn le(&self, other: &Rhs) -> bool
sourceThis method tests less than or equal to (for self and other) and is used by the <=
operator. Read more
impl<'a, 'b> PartialOrd<Cow<'a, OsStr>> for OsString
1.8.0 · source
impl<'a, 'b> PartialOrd<Cow<'a, OsStr>> for OsString
1.8.0 · sourcefn partial_cmp(&self, other: &Cow<'a, OsStr>) -> Option<Ordering>
source
fn partial_cmp(&self, other: &Cow<'a, OsStr>) -> Option<Ordering>
sourceThis method returns an ordering between self and other values if one exists. Read more
fn lt(&self, other: &Rhs) -> bool
source
fn lt(&self, other: &Rhs) -> bool
sourceThis method tests less than (for self and other) and is used by the < operator. Read more
fn le(&self, other: &Rhs) -> bool
source
fn le(&self, other: &Rhs) -> bool
sourceThis method tests less than or equal to (for self and other) and is used by the <=
operator. Read more
impl<'a, 'b> PartialOrd<Cow<'a, Path>> for OsString
1.8.0 · source
impl<'a, 'b> PartialOrd<Cow<'a, Path>> for OsString
1.8.0 · sourcefn partial_cmp(&self, other: &Cow<'a, Path>) -> Option<Ordering>
source
fn partial_cmp(&self, other: &Cow<'a, Path>) -> Option<Ordering>
sourceThis method returns an ordering between self and other values if one exists. Read more
fn lt(&self, other: &Rhs) -> bool
source
fn lt(&self, other: &Rhs) -> bool
sourceThis method tests less than (for self and other) and is used by the < operator. Read more
fn le(&self, other: &Rhs) -> bool
source
fn le(&self, other: &Rhs) -> bool
sourceThis method tests less than or equal to (for self and other) and is used by the <=
operator. Read more
impl<'a, 'b> PartialOrd<OsStr> for OsString
1.8.0 · source
impl<'a, 'b> PartialOrd<OsStr> for OsString
1.8.0 · sourcefn partial_cmp(&self, other: &OsStr) -> Option<Ordering>
source
fn partial_cmp(&self, other: &OsStr) -> Option<Ordering>
sourceThis method returns an ordering between self and other values if one exists. Read more
fn lt(&self, other: &Rhs) -> bool
source
fn lt(&self, other: &Rhs) -> bool
sourceThis method tests less than (for self and other) and is used by the < operator. Read more
fn le(&self, other: &Rhs) -> bool
source
fn le(&self, other: &Rhs) -> bool
sourceThis method tests less than or equal to (for self and other) and is used by the <=
operator. Read more
impl PartialOrd<OsString> for OsString
source
impl PartialOrd<OsString> for OsString
sourcefn partial_cmp(&self, other: &OsString) -> Option<Ordering>
source
fn partial_cmp(&self, other: &OsString) -> Option<Ordering>
sourceThis method returns an ordering between self and other values if one exists. Read more
fn lt(&self, other: &OsString) -> bool
source
fn lt(&self, other: &OsString) -> bool
sourceThis method tests less than (for self and other) and is used by the < operator. Read more
fn le(&self, other: &OsString) -> bool
source
fn le(&self, other: &OsString) -> bool
sourceThis method tests less than or equal to (for self and other) and is used by the <=
operator. Read more
impl<'a, 'b> PartialOrd<OsString> for OsStr
1.8.0 · source
impl<'a, 'b> PartialOrd<OsString> for OsStr
1.8.0 · sourcefn partial_cmp(&self, other: &OsString) -> Option<Ordering>
source
fn partial_cmp(&self, other: &OsString) -> Option<Ordering>
sourceThis method returns an ordering between self and other values if one exists. Read more
fn lt(&self, other: &Rhs) -> bool
source
fn lt(&self, other: &Rhs) -> bool
sourceThis method tests less than (for self and other) and is used by the < operator. Read more
fn le(&self, other: &Rhs) -> bool
source
fn le(&self, other: &Rhs) -> bool
sourceThis method tests less than or equal to (for self and other) and is used by the <=
operator. Read more
impl<'a, 'b> PartialOrd<OsString> for &'a OsStr
1.8.0 · source
impl<'a, 'b> PartialOrd<OsString> for &'a OsStr
1.8.0 · sourcefn partial_cmp(&self, other: &OsString) -> Option<Ordering>
source
fn partial_cmp(&self, other: &OsString) -> Option<Ordering>
sourceThis method returns an ordering between self and other values if one exists. Read more
fn lt(&self, other: &Rhs) -> bool
source
fn lt(&self, other: &Rhs) -> bool
sourceThis method tests less than (for self and other) and is used by the < operator. Read more
fn le(&self, other: &Rhs) -> bool
source
fn le(&self, other: &Rhs) -> bool
sourceThis method tests less than or equal to (for self and other) and is used by the <=
operator. Read more
impl<'a, 'b> PartialOrd<OsString> for Cow<'a, OsStr>
1.8.0 · source
impl<'a, 'b> PartialOrd<OsString> for Cow<'a, OsStr>
1.8.0 · sourcefn partial_cmp(&self, other: &OsString) -> Option<Ordering>
source
fn partial_cmp(&self, other: &OsString) -> Option<Ordering>
sourceThis method returns an ordering between self and other values if one exists. Read more
fn lt(&self, other: &Rhs) -> bool
source
fn lt(&self, other: &Rhs) -> bool
sourceThis method tests less than (for self and other) and is used by the < operator. Read more
fn le(&self, other: &Rhs) -> bool
source
fn le(&self, other: &Rhs) -> bool
sourceThis method tests less than or equal to (for self and other) and is used by the <=
operator. Read more
impl<'a, 'b> PartialOrd<OsString> for PathBuf
1.8.0 · source
impl<'a, 'b> PartialOrd<OsString> for PathBuf
1.8.0 · sourcefn partial_cmp(&self, other: &OsString) -> Option<Ordering>
source
fn partial_cmp(&self, other: &OsString) -> Option<Ordering>
sourceThis method returns an ordering between self and other values if one exists. Read more
fn lt(&self, other: &Rhs) -> bool
source
fn lt(&self, other: &Rhs) -> bool
sourceThis method tests less than (for self and other) and is used by the < operator. Read more
fn le(&self, other: &Rhs) -> bool
source
fn le(&self, other: &Rhs) -> bool
sourceThis method tests less than or equal to (for self and other) and is used by the <=
operator. Read more
impl<'a, 'b> PartialOrd<OsString> for Path
1.8.0 · source
impl<'a, 'b> PartialOrd<OsString> for Path
1.8.0 · sourcefn partial_cmp(&self, other: &OsString) -> Option<Ordering>
source
fn partial_cmp(&self, other: &OsString) -> Option<Ordering>
sourceThis method returns an ordering between self and other values if one exists. Read more
fn lt(&self, other: &Rhs) -> bool
source
fn lt(&self, other: &Rhs) -> bool
sourceThis method tests less than (for self and other) and is used by the < operator. Read more
fn le(&self, other: &Rhs) -> bool
source
fn le(&self, other: &Rhs) -> bool
sourceThis method tests less than or equal to (for self and other) and is used by the <=
operator. Read more
impl<'a, 'b> PartialOrd<OsString> for &'a Path
1.8.0 · source
impl<'a, 'b> PartialOrd<OsString> for &'a Path
1.8.0 · sourcefn partial_cmp(&self, other: &OsString) -> Option<Ordering>
source
fn partial_cmp(&self, other: &OsString) -> Option<Ordering>
sourceThis method returns an ordering between self and other values if one exists. Read more
fn lt(&self, other: &Rhs) -> bool
source
fn lt(&self, other: &Rhs) -> bool
sourceThis method tests less than (for self and other) and is used by the < operator. Read more
fn le(&self, other: &Rhs) -> bool
source
fn le(&self, other: &Rhs) -> bool
sourceThis method tests less than or equal to (for self and other) and is used by the <=
operator. Read more
impl<'a, 'b> PartialOrd<OsString> for Cow<'a, Path>
1.8.0 · source
impl<'a, 'b> PartialOrd<OsString> for Cow<'a, Path>
1.8.0 · sourcefn partial_cmp(&self, other: &OsString) -> Option<Ordering>
source
fn partial_cmp(&self, other: &OsString) -> Option<Ordering>
sourceThis method returns an ordering between self and other values if one exists. Read more
fn lt(&self, other: &Rhs) -> bool
source
fn lt(&self, other: &Rhs) -> bool
sourceThis method tests less than (for self and other) and is used by the < operator. Read more
fn le(&self, other: &Rhs) -> bool
source
fn le(&self, other: &Rhs) -> bool
sourceThis method tests less than or equal to (for self and other) and is used by the <=
operator. Read more
impl<'a, 'b> PartialOrd<Path> for OsString
1.8.0 · source
impl<'a, 'b> PartialOrd<Path> for OsString
1.8.0 · sourcefn partial_cmp(&self, other: &Path) -> Option<Ordering>
source
fn partial_cmp(&self, other: &Path) -> Option<Ordering>
sourceThis method returns an ordering between self and other values if one exists. Read more
fn lt(&self, other: &Rhs) -> bool
source
fn lt(&self, other: &Rhs) -> bool
sourceThis method tests less than (for self and other) and is used by the < operator. Read more
fn le(&self, other: &Rhs) -> bool
source
fn le(&self, other: &Rhs) -> bool
sourceThis method tests less than or equal to (for self and other) and is used by the <=
operator. Read more
impl<'a, 'b> PartialOrd<PathBuf> for OsString
1.8.0 · source
impl<'a, 'b> PartialOrd<PathBuf> for OsString
1.8.0 · sourcefn partial_cmp(&self, other: &PathBuf) -> Option<Ordering>
source
fn partial_cmp(&self, other: &PathBuf) -> Option<Ordering>
sourceThis method returns an ordering between self and other values if one exists. Read more
fn lt(&self, other: &Rhs) -> bool
source
fn lt(&self, other: &Rhs) -> bool
sourceThis method tests less than (for self and other) and is used by the < operator. Read more
fn le(&self, other: &Rhs) -> bool
source
fn le(&self, other: &Rhs) -> bool
sourceThis method tests less than or equal to (for self and other) and is used by the <=
operator. Read more
impl PartialOrd<str> for OsString
source
impl PartialOrd<str> for OsString
sourcefn partial_cmp(&self, other: &str) -> Option<Ordering>
source
fn partial_cmp(&self, other: &str) -> Option<Ordering>
sourceThis method returns an ordering between self and other values if one exists. Read more
fn lt(&self, other: &Rhs) -> bool
source
fn lt(&self, other: &Rhs) -> bool
sourceThis method tests less than (for self and other) and is used by the < operator. Read more
fn le(&self, other: &Rhs) -> bool
source
fn le(&self, other: &Rhs) -> bool
sourceThis method tests less than or equal to (for self and other) and is used by the <=
operator. Read more
impl Eq for OsString
sourceAuto Trait Implementations
impl RefUnwindSafe for OsString
impl Send for OsString
impl Sync for OsString
impl Unpin for OsString
impl UnwindSafe for OsString
Blanket Implementations
impl<T> BorrowMut<T> for T where
T: ?Sized,
source
impl<T> BorrowMut<T> for T where
T: ?Sized,
sourcefn borrow_mut(&mut self) -> &mut T
const: unstable · source
fn borrow_mut(&mut self) -> &mut T
const: unstable · sourceMutably borrows from an owned value. Read more
impl<T> ToOwned for T where
T: Clone,
source
impl<T> ToOwned for T where
T: Clone,
sourcetype Owned = T
type Owned = T
The resulting type after obtaining ownership.
fn clone_into(&self, target: &mut T)
source
fn clone_into(&self, target: &mut T)
sourceUses borrowed data to replace owned data, usually by cloning. Read more