devela::_dep::_std::ffi::os_str

Struct OsString

Source
pub struct OsString { /* private fields */ }
๐Ÿ”ฌThis is a nightly-only experimental API. (os_str_display)
Available on crate feature std only.
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.

ยงCapacity of OsString

Capacity uses units of UTF-8 bytes for OS strings which were created from valid unicode, and uses units of bytes in an unspecified encoding for other contents. On a given target, all OsString and OsStr values use the same units for capacity, so the following will work:

use std::ffi::{OsStr, OsString};

fn concat_os_strings(a: &OsStr, b: &OsStr) -> OsString {
    let mut ret = OsString::with_capacity(a.len() + b.len()); // This will allocate
    ret.push(a); // This will not allocate further
    ret.push(b); // This will not allocate further
    ret
}

ยง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ยง

Sourceยง

impl OsString

1.0.0 ยท Source

pub fn new() -> OsString

Constructs a new empty OsString.

ยงExamples
use std::ffi::OsString;

let os_string = OsString::new();
1.74.0 ยท Source

pub unsafe fn from_encoded_bytes_unchecked(bytes: Vec<u8>) -> OsString

Converts bytes to an OsString without checking that the bytes contains valid OsStr-encoded data.

The byte encoding is an unspecified, platform-specific, self-synchronizing superset of UTF-8. By being a self-synchronizing superset of UTF-8, this encoding is also a superset of 7-bit ASCII.

See the moduleโ€™s toplevel documentation about conversions for safe, cross-platform conversions from/to native representations.

ยงSafety

As the encoding is unspecified, callers must pass in bytes that originated as a mixture of validated UTF-8 and bytes from OsStr::as_encoded_bytes from within the same Rust version built for the same target platform. For example, reconstructing an OsString from bytes sent over the network or stored in a file will likely violate these safety rules.

Due to the encoding being self-synchronizing, the bytes from OsStr::as_encoded_bytes can be split either immediately before or immediately after any valid non-empty UTF-8 substring.

ยงExample
use std::ffi::OsStr;

let os_str = OsStr::new("Mary had a little lamb");
let bytes = os_str.as_encoded_bytes();
let words = bytes.split(|b| *b == b' ');
let words: Vec<&OsStr> = words.map(|word| {
    // SAFETY:
    // - Each `word` only contains content that originated from `OsStr::as_encoded_bytes`
    // - Only split with ASCII whitespace which is a non-empty UTF-8 substring
    unsafe { OsStr::from_encoded_bytes_unchecked(word) }
}).collect();
1.0.0 ยท Source

pub fn as_os_str(&self) -> &OsStr

Converts to an OsStr slice.

ยงExamples
use std::ffi::{OsString, OsStr};

let os_string = OsString::from("foo");
let os_str = OsStr::new("foo");
assert_eq!(os_string.as_os_str(), os_str);
1.74.0 ยท Source

pub fn into_encoded_bytes(self) -> Vec<u8> โ“˜

Converts the OsString into a byte slice. To convert the byte slice back into an OsString, use the OsStr::from_encoded_bytes_unchecked function.

The byte encoding is an unspecified, platform-specific, self-synchronizing superset of UTF-8. By being a self-synchronizing superset of UTF-8, this encoding is also a superset of 7-bit ASCII.

Note: As the encoding is unspecified, any sub-slice of bytes that is not valid UTF-8 should be treated as opaque and only comparable within the same Rust version built for the same target platform. For example, sending the bytes over the network or storing it in a file will likely result in incompatible data. See OsString for more encoding details and std::ffi for platform-specific, specified conversions.

1.0.0 ยท Source

pub fn into_string(self) -> Result<String, OsString> โ“˜

Converts the OsString into a String if it contains valid Unicode data.

On failure, ownership of the original OsString is returned.

ยงExamples
use std::ffi::OsString;

let os_string = OsString::from("foo");
let string = os_string.into_string();
assert_eq!(string, Ok(String::from("foo")));
1.0.0 ยท Source

pub fn push<T>(&mut self, s: T)
where T: AsRef<OsStr>,

Extends the string with the given &OsStr slice.

ยงExamples
use std::ffi::OsString;

let mut os_string = OsString::from("foo");
os_string.push("bar");
assert_eq!(&os_string, "foobar");
1.9.0 ยท Source

pub fn with_capacity(capacity: usize) -> OsString

Creates a new OsString with at least the given capacity.

The string will be able to hold at least capacity length units of other OS strings without reallocating. This method is allowed to allocate for more units than capacity. If capacity is 0, the string will not allocate.

See the main OsString documentation information about encoding and capacity units.

ยง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());
1.9.0 ยท Source

pub fn clear(&mut self)

Truncates the OsString to zero length.

ยงExamples
use std::ffi::OsString;

let mut os_string = OsString::from("foo");
assert_eq!(&os_string, "foo");

os_string.clear();
assert_eq!(&os_string, "");
1.9.0 ยท Source

pub fn capacity(&self) -> usize โ“˜

Returns the capacity this OsString can hold without reallocating.

See the main OsString documentation information about encoding and capacity units.

ยงExamples
use std::ffi::OsString;

let os_string = OsString::with_capacity(10);
assert!(os_string.capacity() >= 10);
1.9.0 ยท Source

pub fn reserve(&mut self, additional: usize)

Reserves capacity for at least additional more capacity to be inserted in the given OsString. Does nothing if the capacity is already sufficient.

The collection may reserve more space to speculatively avoid frequent reallocations.

See the main OsString documentation information about encoding and capacity units.

ยงExamples
use std::ffi::OsString;

let mut s = OsString::new();
s.reserve(10);
assert!(s.capacity() >= 10);
1.63.0 ยท Source

pub fn try_reserve(&mut self, additional: usize) -> Result<(), TryReserveError> โ“˜

Tries to reserve capacity for at least additional more length units in the given OsString. The string may reserve more space to speculatively avoid frequent reallocations. After calling try_reserve, capacity will be greater than or equal to self.len() + additional if it returns Ok(()). Does nothing if capacity is already sufficient. This method preserves the contents even if an error occurs.

See the main OsString documentation information about encoding and capacity units.

ยงErrors

If the capacity overflows, or the allocator reports a failure, then an error is returned.

ยงExamples
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)
}
1.9.0 ยท Source

pub fn reserve_exact(&mut self, additional: usize)

Reserves the minimum capacity for at least 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.

See the main OsString documentation information about encoding and capacity units.

ยงExamples
use std::ffi::OsString;

let mut s = OsString::new();
s.reserve_exact(10);
assert!(s.capacity() >= 10);
1.63.0 ยท Source

pub fn try_reserve_exact( &mut self, additional: usize, ) -> Result<(), TryReserveError> โ“˜

Tries to reserve the minimum capacity for at least 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.

See the main OsString documentation information about encoding and capacity units.

ยงErrors

If the capacity overflows, or the allocator reports a failure, then an error is returned.

ยงExamples
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)
}
1.19.0 ยท Source

pub fn shrink_to_fit(&mut self)

Shrinks the capacity of the OsString to match its length.

See the main OsString documentation information about encoding and capacity units.

ยงExamples
use std::ffi::OsString;

let mut s = OsString::from("foo");

s.reserve(100);
assert!(s.capacity() >= 100);

s.shrink_to_fit();
assert_eq!(3, s.capacity());
1.56.0 ยท Source

pub fn shrink_to(&mut self, min_capacity: usize)

Shrinks 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.

See the main OsString documentation information about encoding and capacity units.

ยง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);
1.20.0 ยท Source

pub fn into_boxed_os_str(self) -> Box<OsStr>

Converts this OsString into a boxed OsStr.

ยงExamples
use std::ffi::{OsString, OsStr};

let s = OsString::from("hello");

let b: Box<OsStr> = s.into_boxed_os_str();
Source

pub fn leak<'a>(self) -> &'a mut OsStr

๐Ÿ”ฌThis is a nightly-only experimental API. (os_string_pathbuf_leak)

Consumes and leaks the OsString, returning a mutable reference to the contents, &'a mut OsStr.

The caller has free choice over the returned lifetime, including โ€™static. Indeed, this function is ideally used for data that lives for the remainder of the programโ€™s life, as dropping the returned reference will cause a memory leak.

It does not reallocate or shrink the OsString, so the leaked allocation may include unused capacity that is not part of the returned slice. If you want to discard excess capacity, call into_boxed_os_str, and then Box::leak instead. However, keep in mind that trimming the capacity may result in a reallocation and copy.

Source

pub fn truncate(&mut self, len: usize)

๐Ÿ”ฌThis is a nightly-only experimental API. (os_string_truncate)

Truncate the OsString to the specified length.

ยงPanics

Panics if len does not lie on a valid OsStr boundary (as described in OsStr::slice_encoded_bytes).

Methods from Deref<Target = OsStr>ยง

1.0.0 ยท Source

pub fn to_str(&self) -> Option<&str> โ“˜

Yields a &str slice if the OsStr is valid Unicode.

This conversion may entail doing a check for UTF-8 validity.

ยงExamples
use std::ffi::OsStr;

let os_str = OsStr::new("foo");
assert_eq!(os_str.to_str(), Some("foo"));
1.0.0 ยท Source

pub fn to_string_lossy(&self) -> Cow<'_, str>

Converts an OsStr to a Cow<str>.

Any non-UTF-8 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");
}
1.0.0 ยท Source

pub fn to_os_string(&self) -> OsString

Copies the slice into an owned OsString.

ยงExamples
use std::ffi::{OsStr, OsString};

let os_str = OsStr::new("foo");
let os_string = os_str.to_os_string();
assert_eq!(os_string, OsString::from("foo"));
1.9.0 ยท Source

pub fn is_empty(&self) -> bool

Checks whether the OsStr is empty.

ยงExamples
use std::ffi::OsStr;

let os_str = OsStr::new("");
assert!(os_str.is_empty());

let os_str = OsStr::new("foo");
assert!(!os_str.is_empty());
1.9.0 ยท Source

pub fn len(&self) -> usize โ“˜

Returns 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.

See the main OsString documentation information about encoding and capacity units.

ยง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);
1.74.0 ยท Source

pub fn as_encoded_bytes(&self) -> &[u8] โ“˜

Converts an OS string slice to a byte slice. To convert the byte slice back into an OS string slice, use the OsStr::from_encoded_bytes_unchecked function.

The byte encoding is an unspecified, platform-specific, self-synchronizing superset of UTF-8. By being a self-synchronizing superset of UTF-8, this encoding is also a superset of 7-bit ASCII.

Note: As the encoding is unspecified, any sub-slice of bytes that is not valid UTF-8 should be treated as opaque and only comparable within the same Rust version built for the same target platform. For example, sending the slice over the network or storing it in a file will likely result in incompatible byte slices. See OsString for more encoding details and std::ffi for platform-specific, specified conversions.

Source

pub fn slice_encoded_bytes<R>(&self, range: R) -> &OsStr
where R: RangeBounds<usize>,

๐Ÿ”ฌThis is a nightly-only experimental API. (os_str_slice)

Takes a substring based on a range that corresponds to the return value of OsStr::as_encoded_bytes.

The rangeโ€™s start and end must lie on valid OsStr boundaries. A valid OsStr boundary is one of:

  • The start of the string
  • The end of the string
  • Immediately before a valid non-empty UTF-8 substring
  • Immediately after a valid non-empty UTF-8 substring
ยงPanics

Panics if range does not lie on valid OsStr boundaries or if it exceeds the end of the string.

ยงExample
#![feature(os_str_slice)]

use std::ffi::OsStr;

let os_str = OsStr::new("foo=bar");
let bytes = os_str.as_encoded_bytes();
if let Some(index) = bytes.iter().position(|b| *b == b'=') {
    let key = os_str.slice_encoded_bytes(..index);
    let value = os_str.slice_encoded_bytes(index + 1..);
    assert_eq!(key, "foo");
    assert_eq!(value, "bar");
}
1.53.0 ยท Source

pub fn make_ascii_lowercase(&mut self)

Converts 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);
1.53.0 ยท Source

pub fn make_ascii_uppercase(&mut self)

Converts 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);
1.53.0 ยท Source

pub fn to_ascii_lowercase(&self) -> OsString

Returns 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());
1.53.0 ยท Source

pub fn to_ascii_uppercase(&self) -> OsString

Returns 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());
1.53.0 ยท Source

pub fn is_ascii(&self) -> bool

Checks if all characters in this string are within the ASCII range.

ยงExamples
use std::ffi::OsString;

let ascii = OsString::from("hello!\n");
let non_ascii = OsString::from("GrรผรŸe, Jรผrgen โค");

assert!(ascii.is_ascii());
assert!(!non_ascii.is_ascii());
1.53.0 ยท Source

pub fn eq_ignore_ascii_case<S>(&self, other: S) -> bool
where S: AsRef<OsStr>,

Checks 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"));
Source

pub fn display(&self) -> Display<'_>

๐Ÿ”ฌThis is a nightly-only experimental API. (os_str_display)

Returns an object that implements Display for safely printing an OsStr that may contain non-Unicode data. This may perform lossy conversion, depending on the platform. If you would like an implementation which escapes the OsStr please use Debug instead.

ยงExamples
#![feature(os_str_display)]
use std::ffi::OsStr;

let s = OsStr::new("Hello, world!");
println!("{}", s.display());

Trait Implementationsยง

ยง

impl ArchiveWith<OsString> for AsString

ยง

type Archived = ArchivedString

The archived type of Self with F.
ยง

type Resolver = StringResolver

The resolver of a Self with F.
ยง

fn resolve_with( field: &OsString, resolver: <AsString as ArchiveWith<OsString>>::Resolver, out: Place<<AsString as ArchiveWith<OsString>>::Archived>, )

Resolves the archived type using a reference to the field type F.
ยง

impl Arg for &OsString

ยง

fn as_str(&self) -> Result<&str, Errno> โ“˜

Returns a view of this string as a string slice.
ยง

fn to_string_lossy(&self) -> Cow<'_, str>

Returns a potentially-lossy rendering of this string as a Cow<'_, str>.
ยง

fn as_cow_c_str(&self) -> Result<Cow<'_, CStr>, Errno> โ“˜

Returns a view of this string as a maybe-owned CStr.
ยง

fn into_c_str<'b>(self) -> Result<Cow<'b, CStr>, Errno> โ“˜
where &OsString: 'b,

Consumes self and returns a view of this string as a maybe-owned CStr.
ยง

fn into_with_c_str<T, F>(self, f: F) -> Result<T, Errno> โ“˜
where &OsString: Sized, F: FnOnce(&CStr) -> Result<T, Errno>,

Runs a closure with self passed in as a &CStr.
ยง

impl Arg for OsString

ยง

fn as_str(&self) -> Result<&str, Errno> โ“˜

Returns a view of this string as a string slice.
ยง

fn to_string_lossy(&self) -> Cow<'_, str>

Returns a potentially-lossy rendering of this string as a Cow<'_, str>.
ยง

fn as_cow_c_str(&self) -> Result<Cow<'_, CStr>, Errno> โ“˜

Returns a view of this string as a maybe-owned CStr.
ยง

fn into_c_str<'b>(self) -> Result<Cow<'b, CStr>, Errno> โ“˜
where OsString: 'b,

Consumes self and returns a view of this string as a maybe-owned CStr.
ยง

fn into_with_c_str<T, F>(self, f: F) -> Result<T, Errno> โ“˜
where OsString: Sized, F: FnOnce(&CStr) -> Result<T, Errno>,

Runs a closure with self passed in as a &CStr.
1.0.0 ยท Sourceยง

impl AsRef<OsStr> for OsString

Sourceยง

fn as_ref(&self) -> &OsStr

Converts this type into a shared reference of the (usually inferred) input type.
1.0.0 ยท Sourceยง

impl AsRef<Path> for OsString

Sourceยง

fn as_ref(&self) -> &Path โ“˜

Converts this type into a shared reference of the (usually inferred) input type.
ยง

impl AsRef<Path> for OsString

ยง

fn as_ref(&self) -> &Path

Converts this type into a shared reference of the (usually inferred) input type.
1.0.0 ยท Sourceยง

impl Borrow<OsStr> for OsString

Sourceยง

fn borrow(&self) -> &OsStr

Immutably borrows from an owned value. Read more
1.0.0 ยท Sourceยง

impl Clone for OsString

Sourceยง

fn clone_from(&mut self, source: &OsString)

Clones the contents of source into self.

This method is preferred over simply assigning source.clone() to self, as it avoids reallocation if possible.

Sourceยง

fn clone(&self) -> OsString

Returns a copy of the value. Read more
1.0.0 ยท Sourceยง

impl Debug for OsString

Sourceยง

fn fmt(&self, formatter: &mut Formatter<'_>) -> Result<(), Error> โ“˜

Formats the value using the given formatter. Read more
1.9.0 ยท Sourceยง

impl Default for OsString

Sourceยง

fn default() -> OsString

Constructs an empty OsString.

1.0.0 ยท Sourceยง

impl Deref for OsString

Sourceยง

type Target = OsStr

The resulting type after dereferencing.
Sourceยง

fn deref(&self) -> &OsStr

Dereferences the value.
1.44.0 ยท Sourceยง

impl DerefMut for OsString

Sourceยง

fn deref_mut(&mut self) -> &mut OsStr

Mutably dereferences the value.
Sourceยง

impl<'de> Deserialize<'de> for OsString

Sourceยง

fn deserialize<D>( deserializer: D, ) -> Result<OsString, <D as Deserializer<'de>>::Error> โ“˜
where D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
ยง

impl<D> DeserializeWith<ArchivedString, OsString, D> for AsString
where D: Fallible + ?Sized,

ยง

fn deserialize_with( field: &ArchivedString, _: &mut D, ) -> Result<OsString, <D as Fallible>::Error> โ“˜

Deserializes the field type F using the given deserializer.
1.52.0 ยท Sourceยง

impl<'a> Extend<&'a OsStr> for OsString

Sourceยง

fn extend<T>(&mut self, iter: T)
where T: IntoIterator<Item = &'a OsStr>,

Extends a collection with the contents of an iterator. Read more
Sourceยง

fn extend_one(&mut self, item: A)

๐Ÿ”ฌThis is a nightly-only experimental API. (extend_one)
Extends a collection with exactly one element.
Sourceยง

fn extend_reserve(&mut self, additional: usize)

๐Ÿ”ฌThis is a nightly-only experimental API. (extend_one)
Reserves capacity in a collection for the given number of additional elements. Read more
1.52.0 ยท Sourceยง

impl<'a> Extend<Cow<'a, OsStr>> for OsString

Sourceยง

fn extend<T>(&mut self, iter: T)
where T: IntoIterator<Item = Cow<'a, OsStr>>,

Extends a collection with the contents of an iterator. Read more
Sourceยง

fn extend_one(&mut self, item: A)

๐Ÿ”ฌThis is a nightly-only experimental API. (extend_one)
Extends a collection with exactly one element.
Sourceยง

fn extend_reserve(&mut self, additional: usize)

๐Ÿ”ฌThis is a nightly-only experimental API. (extend_one)
Reserves capacity in a collection for the given number of additional elements. Read more
1.52.0 ยท Sourceยง

impl Extend<OsString> for OsString

Sourceยง

fn extend<T>(&mut self, iter: T)
where T: IntoIterator<Item = OsString>,

Extends a collection with the contents of an iterator. Read more
Sourceยง

fn extend_one(&mut self, item: A)

๐Ÿ”ฌThis is a nightly-only experimental API. (extend_one)
Extends a collection with exactly one element.
Sourceยง

fn extend_reserve(&mut self, additional: usize)

๐Ÿ”ฌThis is a nightly-only experimental API. (extend_one)
Reserves capacity in a collection for the given number of additional elements. Read more
1.28.0 ยท Sourceยง

impl<'a> From<&'a OsString> for Cow<'a, OsStr>

Sourceยง

fn from(s: &'a OsString) -> Cow<'a, OsStr>

Converts the string reference into a Cow::Borrowed.

1.0.0 ยท Sourceยง

impl<T> From<&T> for OsString
where T: AsRef<OsStr> + ?Sized,

Sourceยง

fn from(s: &T) -> OsString

Copies any value implementing AsRef<OsStr> into a newly allocated OsString.

1.18.0 ยท Sourceยง

impl From<Box<OsStr>> for OsString

Sourceยง

fn from(boxed: Box<OsStr>) -> OsString

Converts a Box<OsStr> into an OsString without copying or allocating.

1.28.0 ยท Sourceยง

impl<'a> From<Cow<'a, OsStr>> for OsString

Sourceยง

fn from(s: Cow<'a, OsStr>) -> OsString

Converts a Cow<'a, OsStr> into an OsString, by copying the contents if they are borrowed.

1.24.0 ยท Sourceยง

impl From<OsString> for Arc<OsStr>

Sourceยง

fn from(s: OsString) -> Arc<OsStr>

Converts an OsString into an Arc<OsStr> by moving the OsString data into a new Arc buffer.

1.20.0 ยท Sourceยง

impl From<OsString> for Box<OsStr>

Sourceยง

fn from(s: OsString) -> Box<OsStr>

Converts an OsString into a Box<OsStr> without copying or allocating.

1.28.0 ยท Sourceยง

impl<'a> From<OsString> for Cow<'a, OsStr>

Sourceยง

fn from(s: OsString) -> Cow<'a, OsStr>

Moves the string into a Cow::Owned.

1.0.0 ยท Sourceยง

impl From<OsString> for PathBuf

Sourceยง

fn from(s: OsString) -> PathBuf โ“˜

Converts an OsString into a PathBuf.

This conversion does not allocate or copy memory.

1.24.0 ยท Sourceยง

impl From<OsString> for Rc<OsStr>

Sourceยง

fn from(s: OsString) -> Rc<OsStr>

Converts an OsString into an Rc<OsStr> by moving the OsString data into a new Rc buffer.

1.14.0 ยท Sourceยง

impl From<PathBuf> for OsString

Sourceยง

fn from(path_buf: PathBuf) -> OsString

Converts a PathBuf into an OsString

This conversion does not allocate or copy memory.

1.0.0 ยท Sourceยง

impl From<String> for OsString

Sourceยง

fn from(s: String) -> OsString

Converts a String into an OsString.

This conversion does not allocate or copy memory.

1.52.0 ยท Sourceยง

impl<'a> FromIterator<&'a OsStr> for OsString

Sourceยง

fn from_iter<I>(iter: I) -> OsString
where I: IntoIterator<Item = &'a OsStr>,

Creates a value from an iterator. Read more
1.52.0 ยท Sourceยง

impl<'a> FromIterator<Cow<'a, OsStr>> for OsString

Sourceยง

fn from_iter<I>(iter: I) -> OsString
where I: IntoIterator<Item = Cow<'a, OsStr>>,

Creates a value from an iterator. Read more
1.52.0 ยท Sourceยง

impl FromIterator<OsString> for OsString

Sourceยง

fn from_iter<I>(iter: I) -> OsString
where I: IntoIterator<Item = OsString>,

Creates a value from an iterator. Read more
ยง

impl<'a> FromParallelIterator<&'a OsStr> for OsString

Collects OS-string slices from a parallel iterator into an OS-string.

ยง

fn from_par_iter<I>(par_iter: I) -> OsString
where I: IntoParallelIterator<Item = &'a OsStr>,

Creates an instance of the collection from the parallel iterator par_iter. Read more
ยง

impl<'a> FromParallelIterator<Cow<'a, OsStr>> for OsString

Collects OS-string slices from a parallel iterator into an OS-string.

ยง

fn from_par_iter<I>(par_iter: I) -> OsString
where I: IntoParallelIterator<Item = Cow<'a, OsStr>>,

Creates an instance of the collection from the parallel iterator par_iter. Read more
ยง

impl FromParallelIterator<OsString> for OsString

Collects OS-strings from a parallel iterator into one large OS-string.

ยง

fn from_par_iter<I>(par_iter: I) -> OsString
where I: IntoParallelIterator<Item = OsString>,

Creates an instance of the collection from the parallel iterator par_iter. Read more
ยง

impl FromPyObject<'_> for OsString

ยง

fn extract_bound(ob: &Bound<'_, PyAny>) -> Result<OsString, PyErr> โ“˜

Extracts Self from the bound smart pointer obj. Read more
1.45.0 ยท Sourceยง

impl FromStr for OsString

Sourceยง

type Err = Infallible

The associated error which can be returned from parsing.
Sourceยง

fn from_str(s: &str) -> Result<OsString, <OsString as FromStr>::Err> โ“˜

Parses a string s to return a value of this type. Read more
1.0.0 ยท Sourceยง

impl Hash for OsString

Sourceยง

fn hash<H>(&self, state: &mut H)
where H: Hasher,

Feeds this value into the given Hasher. Read more
1.3.0 ยท Sourceยง

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
1.0.0 ยท Sourceยง

impl Index<RangeFull> for OsString

Sourceยง

type Output = OsStr

The returned type after indexing.
Sourceยง

fn index(&self, _index: RangeFull) -> &OsStr

Performs the indexing (container[index]) operation. Read more
1.44.0 ยท Sourceยง

impl IndexMut<RangeFull> for OsString

Sourceยง

fn index_mut(&mut self, _index: RangeFull) -> &mut OsStr

Performs the mutable indexing (container[index]) operation. Read more
ยง

impl IntoPy<Py<PyAny>> for &OsString

ยง

fn into_py(self, py: Python<'_>) -> Py<PyAny>

๐Ÿ‘ŽDeprecated since 0.23.0: IntoPy is going to be replaced by IntoPyObject. See the migration guide (https://pyo3.rs/v0.23.0/migration) for more information.
Performs the conversion.
ยง

impl IntoPy<Py<PyAny>> for OsString

ยง

fn into_py(self, py: Python<'_>) -> Py<PyAny>

๐Ÿ‘ŽDeprecated since 0.23.0: IntoPy is going to be replaced by IntoPyObject. See the migration guide (https://pyo3.rs/v0.23.0/migration) for more information.
Performs the conversion.
ยง

impl<'py> IntoPyObject<'py> for &OsString

ยง

type Target = PyString

The Python output type
ยง

type Output = Bound<'py, <&OsString as IntoPyObject<'py>>::Target>

The smart pointer type to use. Read more
ยง

type Error = Infallible

The type returned in the event of a conversion error.
ยง

fn into_pyobject( self, py: Python<'py>, ) -> Result<<&OsString as IntoPyObject<'py>>::Output, <&OsString as IntoPyObject<'py>>::Error> โ“˜

Performs the conversion.
ยง

impl<'py> IntoPyObject<'py> for OsString

ยง

type Target = PyString

The Python output type
ยง

type Output = Bound<'py, <OsString as IntoPyObject<'py>>::Target>

The smart pointer type to use. Read more
ยง

type Error = Infallible

The type returned in the event of a conversion error.
ยง

fn into_pyobject( self, py: Python<'py>, ) -> Result<<OsString as IntoPyObject<'py>>::Output, <OsString as IntoPyObject<'py>>::Error> โ“˜

Performs the conversion.
1.0.0 ยท Sourceยง

impl Ord for OsString

Sourceยง

fn cmp(&self, other: &OsString) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 ยท Sourceยง

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 ยท Sourceยง

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 ยท Sourceยง

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
1.0.0 ยท Sourceยง

impl OsStringExt for OsString

Sourceยง

fn from_vec(vec: Vec<u8>) -> OsString

Creates an OsString from a byte vector. Read more
Sourceยง

fn into_vec(self) -> Vec<u8> โ“˜

Yields the underlying byte vector of this OsString. Read more
ยง

impl<'a> ParallelExtend<&'a OsStr> for OsString

Extends an OS-string with string slices from a parallel iterator.

ยง

fn par_extend<I>(&mut self, par_iter: I)
where I: IntoParallelIterator<Item = &'a OsStr>,

Extends an instance of the collection with the elements drawn from the parallel iterator par_iter. Read more
ยง

impl<'a> ParallelExtend<Cow<'a, OsStr>> for OsString

Extends an OS-string with string slices from a parallel iterator.

ยง

fn par_extend<I>(&mut self, par_iter: I)
where I: IntoParallelIterator<Item = Cow<'a, OsStr>>,

Extends an instance of the collection with the elements drawn from the parallel iterator par_iter. Read more
ยง

impl ParallelExtend<OsString> for OsString

Extends an OS-string with strings from a parallel iterator.

ยง

fn par_extend<I>(&mut self, par_iter: I)
where I: IntoParallelIterator<Item = OsString>,

Extends an instance of the collection with the elements drawn from the parallel iterator par_iter. Read more
1.8.0 ยท Sourceยง

impl<'a, 'b> PartialEq<&'a OsStr> for OsString

Sourceยง

fn eq(&self, other: &&'a OsStr) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 ยท Sourceยง

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
1.8.0 ยท Sourceยง

impl<'a> PartialEq<&'a Path> for OsString

Sourceยง

fn eq(&self, other: &&'a Path) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 ยท Sourceยง

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
1.29.0 ยท Sourceยง

impl PartialEq<&str> for OsString

Sourceยง

fn eq(&self, other: &&str) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 ยท Sourceยง

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
1.8.0 ยท Sourceยง

impl<'a, 'b> PartialEq<Cow<'a, OsStr>> for OsString

Sourceยง

fn eq(&self, other: &Cow<'a, OsStr>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 ยท Sourceยง

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
1.8.0 ยท Sourceยง

impl<'a> PartialEq<Cow<'a, Path>> for OsString

Sourceยง

fn eq(&self, other: &Cow<'a, Path>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 ยท Sourceยง

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
1.8.0 ยท Sourceยง

impl<'a, 'b> PartialEq<OsStr> for OsString

Sourceยง

fn eq(&self, other: &OsStr) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 ยท Sourceยง

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
1.8.0 ยท Sourceยง

impl<'a, 'b> PartialEq<OsString> for &'a OsStr

Sourceยง

fn eq(&self, other: &OsString) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 ยท Sourceยง

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
1.8.0 ยท Sourceยง

impl<'a> PartialEq<OsString> for &'a Path

Sourceยง

fn eq(&self, other: &OsString) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 ยท Sourceยง

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
1.29.0 ยท Sourceยง

impl<'a> PartialEq<OsString> for &'a str

Sourceยง

fn eq(&self, other: &OsString) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 ยท Sourceยง

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
1.8.0 ยท Sourceยง

impl<'a, 'b> PartialEq<OsString> for Cow<'a, OsStr>

Sourceยง

fn eq(&self, other: &OsString) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 ยท Sourceยง

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
1.8.0 ยท Sourceยง

impl<'a> PartialEq<OsString> for Cow<'a, Path>

Sourceยง

fn eq(&self, other: &OsString) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 ยท Sourceยง

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
1.8.0 ยท Sourceยง

impl<'a, 'b> PartialEq<OsString> for OsStr

Sourceยง

fn eq(&self, other: &OsString) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 ยท Sourceยง

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
1.8.0 ยท Sourceยง

impl PartialEq<OsString> for Path

Sourceยง

fn eq(&self, other: &OsString) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 ยท Sourceยง

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
1.8.0 ยท Sourceยง

impl PartialEq<OsString> for PathBuf

Sourceยง

fn eq(&self, other: &OsString) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 ยท Sourceยง

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
1.0.0 ยท Sourceยง

impl PartialEq<OsString> for str

Sourceยง

fn eq(&self, other: &OsString) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 ยท Sourceยง

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
1.8.0 ยท Sourceยง

impl PartialEq<Path> for OsString

Sourceยง

fn eq(&self, other: &Path) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 ยท Sourceยง

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
1.8.0 ยท Sourceยง

impl PartialEq<PathBuf> for OsString

Sourceยง

fn eq(&self, other: &PathBuf) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 ยท Sourceยง

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
1.0.0 ยท Sourceยง

impl PartialEq<str> for OsString

Sourceยง

fn eq(&self, other: &str) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 ยท Sourceยง

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
1.0.0 ยท Sourceยง

impl PartialEq for OsString

Sourceยง

fn eq(&self, other: &OsString) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 ยท Sourceยง

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
1.8.0 ยท Sourceยง

impl<'a, 'b> PartialOrd<&'a OsStr> for OsString

Sourceยง

fn partial_cmp(&self, other: &&'a OsStr) -> Option<Ordering> โ“˜

This method returns an ordering between self and other values if one exists. Read more
1.0.0 ยท Sourceยง

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 ยท Sourceยง

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 ยท Sourceยง

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 ยท Sourceยง

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
1.8.0 ยท Sourceยง

impl<'a> PartialOrd<&'a Path> for OsString

Sourceยง

fn partial_cmp(&self, other: &&'a Path) -> Option<Ordering> โ“˜

This method returns an ordering between self and other values if one exists. Read more
1.0.0 ยท Sourceยง

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 ยท Sourceยง

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 ยท Sourceยง

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 ยท Sourceยง

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
1.8.0 ยท Sourceยง

impl<'a, 'b> PartialOrd<Cow<'a, OsStr>> for OsString

Sourceยง

fn partial_cmp(&self, other: &Cow<'a, OsStr>) -> Option<Ordering> โ“˜

This method returns an ordering between self and other values if one exists. Read more
1.0.0 ยท Sourceยง

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 ยท Sourceยง

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 ยท Sourceยง

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 ยท Sourceยง

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
1.8.0 ยท Sourceยง

impl<'a> PartialOrd<Cow<'a, Path>> for OsString

Sourceยง

fn partial_cmp(&self, other: &Cow<'a, Path>) -> Option<Ordering> โ“˜

This method returns an ordering between self and other values if one exists. Read more
1.0.0 ยท Sourceยง

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 ยท Sourceยง

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 ยท Sourceยง

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 ยท Sourceยง

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
1.8.0 ยท Sourceยง

impl<'a, 'b> PartialOrd<OsStr> for OsString

Sourceยง

fn partial_cmp(&self, other: &OsStr) -> Option<Ordering> โ“˜

This method returns an ordering between self and other values if one exists. Read more
1.0.0 ยท Sourceยง

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 ยท Sourceยง

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 ยท Sourceยง

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 ยท Sourceยง

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
1.8.0 ยท Sourceยง

impl<'a, 'b> PartialOrd<OsString> for &'a OsStr

Sourceยง

fn partial_cmp(&self, other: &OsString) -> Option<Ordering> โ“˜

This method returns an ordering between self and other values if one exists. Read more
1.0.0 ยท Sourceยง

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 ยท Sourceยง

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 ยท Sourceยง

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 ยท Sourceยง

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
1.8.0 ยท Sourceยง

impl<'a> PartialOrd<OsString> for &'a Path

Sourceยง

fn partial_cmp(&self, other: &OsString) -> Option<Ordering> โ“˜

This method returns an ordering between self and other values if one exists. Read more
1.0.0 ยท Sourceยง

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 ยท Sourceยง

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 ยท Sourceยง

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 ยท Sourceยง

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
1.8.0 ยท Sourceยง

impl<'a, 'b> PartialOrd<OsString> for Cow<'a, OsStr>

Sourceยง

fn partial_cmp(&self, other: &OsString) -> Option<Ordering> โ“˜

This method returns an ordering between self and other values if one exists. Read more
1.0.0 ยท Sourceยง

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 ยท Sourceยง

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 ยท Sourceยง

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 ยท Sourceยง

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
1.8.0 ยท Sourceยง

impl<'a> PartialOrd<OsString> for Cow<'a, Path>

Sourceยง

fn partial_cmp(&self, other: &OsString) -> Option<Ordering> โ“˜

This method returns an ordering between self and other values if one exists. Read more
1.0.0 ยท Sourceยง

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 ยท Sourceยง

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 ยท Sourceยง

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 ยท Sourceยง

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
1.8.0 ยท Sourceยง

impl<'a, 'b> PartialOrd<OsString> for OsStr

Sourceยง

fn partial_cmp(&self, other: &OsString) -> Option<Ordering> โ“˜

This method returns an ordering between self and other values if one exists. Read more
1.0.0 ยท Sourceยง

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 ยท Sourceยง

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 ยท Sourceยง

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 ยท Sourceยง

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
1.8.0 ยท Sourceยง

impl PartialOrd<OsString> for Path

Sourceยง

fn partial_cmp(&self, other: &OsString) -> Option<Ordering> โ“˜

This method returns an ordering between self and other values if one exists. Read more
1.0.0 ยท Sourceยง

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 ยท Sourceยง

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 ยท Sourceยง

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 ยท Sourceยง

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
1.8.0 ยท Sourceยง

impl PartialOrd<OsString> for PathBuf

Sourceยง

fn partial_cmp(&self, other: &OsString) -> Option<Ordering> โ“˜

This method returns an ordering between self and other values if one exists. Read more
1.0.0 ยท Sourceยง

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 ยท Sourceยง

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 ยท Sourceยง

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 ยท Sourceยง

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
1.8.0 ยท Sourceยง

impl PartialOrd<Path> for OsString

Sourceยง

fn partial_cmp(&self, other: &Path) -> Option<Ordering> โ“˜

This method returns an ordering between self and other values if one exists. Read more
1.0.0 ยท Sourceยง

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 ยท Sourceยง

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 ยท Sourceยง

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 ยท Sourceยง

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
1.8.0 ยท Sourceยง

impl PartialOrd<PathBuf> for OsString

Sourceยง

fn partial_cmp(&self, other: &PathBuf) -> Option<Ordering> โ“˜

This method returns an ordering between self and other values if one exists. Read more
1.0.0 ยท Sourceยง

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 ยท Sourceยง

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 ยท Sourceยง

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 ยท Sourceยง

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
1.0.0 ยท Sourceยง

impl PartialOrd<str> for OsString

Sourceยง

fn partial_cmp(&self, other: &str) -> Option<Ordering> โ“˜

This method returns an ordering between self and other values if one exists. Read more
1.0.0 ยท Sourceยง

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 ยท Sourceยง

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 ยท Sourceยง

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 ยท Sourceยง

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
1.0.0 ยท Sourceยง

impl PartialOrd for OsString

Sourceยง

fn partial_cmp(&self, other: &OsString) -> Option<Ordering> โ“˜

This method returns an ordering between self and other values if one exists. Read more
Sourceยง

fn lt(&self, other: &OsString) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
Sourceยง

fn le(&self, other: &OsString) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
Sourceยง

fn gt(&self, other: &OsString) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
Sourceยง

fn ge(&self, other: &OsString) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Sourceยง

impl Serialize for OsString

Sourceยง

fn serialize<S>( &self, serializer: S, ) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error> โ“˜
where S: Serializer,

Serialize this value into the given Serde serializer. Read more
ยง

impl<S> SerializeWith<OsString, S> for AsString
where S: Fallible + ?Sized, <S as Fallible>::Error: Source, str: SerializeUnsized<S>,

ยง

fn serialize_with( field: &OsString, serializer: &mut S, ) -> Result<<AsString as ArchiveWith<OsString>>::Resolver, <S as Fallible>::Error> โ“˜

Serializes the field type F using the given serializer.
ยง

impl ToPyObject for OsString

ยง

fn to_object(&self, py: Python<'_>) -> Py<PyAny>

๐Ÿ‘ŽDeprecated since 0.23.0: ToPyObject is going to be replaced by IntoPyObject. See the migration guide (https://pyo3.rs/v0.23.0/migration) for more information.
Converts self into a Python object.
1.64.0 ยท Sourceยง

impl Write for OsString

Sourceยง

fn write_str(&mut self, s: &str) -> Result<(), Error> โ“˜

Writes a string slice into this writer, returning whether the write succeeded. Read more
1.1.0 ยท Sourceยง

fn write_char(&mut self, c: char) -> Result<(), Error> โ“˜

Writes a char into this writer, returning whether the write succeeded. Read more
1.0.0 ยท Sourceยง

fn write_fmt(&mut self, args: Arguments<'_>) -> Result<(), Error> โ“˜

Glue for usage of the write! macro with implementors of this trait. Read more
1.0.0 ยท Sourceยง

impl Eq for OsString

Auto Trait Implementationsยง

Blanket Implementationsยง

Sourceยง

impl<T> Any for T
where T: 'static + ?Sized,

Sourceยง

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
ยง

impl<T> ArchivePointee for T

ยง

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
ยง

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
Sourceยง

impl<T> Borrow<T> for T
where T: ?Sized,

Sourceยง

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Sourceยง

impl<T> BorrowMut<T> for T
where T: ?Sized,

Sourceยง

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Sourceยง

impl<T> ByteSized for T

Sourceยง

const BYTE_ALIGN: usize = _

The alignment of this type in bytes.
Sourceยง

const BYTE_SIZE: usize = _

The size of this type in bytes.
Sourceยง

fn byte_align(&self) -> usize โ“˜

Returns the alignment of this type in bytes.
Sourceยง

fn byte_size(&self) -> usize โ“˜

Returns the size of this type in bytes. Read more
Sourceยง

fn ptr_size_ratio(&self) -> [usize; 2]

Returns the size ratio between Ptr::BYTES and BYTE_SIZE. Read more
Sourceยง

impl<T, R> Chain<R> for T
where T: ?Sized,

Sourceยง

fn chain<F>(self, f: F) -> R
where F: FnOnce(Self) -> R, Self: Sized,

Chain a function which takes the parameter by value.
Sourceยง

fn chain_ref<F>(&self, f: F) -> R
where F: FnOnce(&Self) -> R,

Chain a function which takes the parameter by shared reference.
Sourceยง

fn chain_mut<F>(&mut self, f: F) -> R
where F: FnOnce(&mut Self) -> R,

Chain a function which takes the parameter by exclusive reference.
Sourceยง

impl<T> CloneToUninit for T
where T: Clone,

Sourceยง

unsafe fn clone_to_uninit(&self, dst: *mut u8)

๐Ÿ”ฌThis is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
ยง

impl<Q, K> Comparable<K> for Q
where Q: Ord + ?Sized, K: Borrow<Q> + ?Sized,

ยง

fn compare(&self, key: &K) -> Ordering

Compare self to key and return their ordering.
ยง

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

ยง

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Sourceยง

impl<T> ExtAny for T
where T: Any + ?Sized,

Sourceยง

fn type_id() -> TypeId

Returns the TypeId of Self. Read more
Sourceยง

fn type_of(&self) -> TypeId

Returns the TypeId of self. Read more
Sourceยง

fn type_name(&self) -> &'static str โ“˜

Returns the type name of self. Read more
Sourceยง

fn type_is<T: 'static>(&self) -> bool

Returns true if Self is of type T. Read more
Sourceยง

fn as_any_ref(&self) -> &dyn Any
where Self: Sized,

Upcasts &self as &dyn Any. Read more
Sourceยง

fn as_any_mut(&mut self) -> &mut dyn Any
where Self: Sized,

Upcasts &mut self as &mut dyn Any. Read more
Sourceยง

fn as_any_box(self: Box<Self>) -> Box<dyn Any>
where Self: Sized,

Upcasts Box<self> as Box<dyn Any>. Read more
Sourceยง

fn downcast_ref<T: 'static>(&self) -> Option<&T> โ“˜

Available on crate feature unsafe_layout only.
Returns some shared reference to the inner value if it is of type T. Read more
Sourceยง

fn downcast_mut<T: 'static>(&mut self) -> Option<&mut T> โ“˜

Available on crate feature unsafe_layout only.
Returns some exclusive reference to the inner value if it is of type T. Read more
Sourceยง

impl<T> ExtMem for T
where T: ?Sized,

Sourceยง

const NEEDS_DROP: bool = _

Know whether dropping values of this type matters, in compile-time.
Sourceยง

fn mem_align_of<T>() -> usize โ“˜

Returns the minimum alignment of the type in bytes. Read more
Sourceยง

fn mem_align_of_val(&self) -> usize โ“˜

Returns the alignment of the pointed-to value in bytes. Read more
Sourceยง

fn mem_size_of<T>() -> usize โ“˜

Returns the size of a type in bytes. Read more
Sourceยง

fn mem_size_of_val(&self) -> usize โ“˜

Returns the size of the pointed-to value in bytes. Read more
Sourceยง

fn mem_copy(&self) -> Self
where Self: Copy,

Bitwise-copies a value. Read more
Sourceยง

fn mem_needs_drop(&self) -> bool

Returns true if dropping values of this type matters. Read more
Sourceยง

fn mem_drop(self)
where Self: Sized,

Drops self by running its destructor. Read more
Sourceยง

fn mem_forget(self)
where Self: Sized,

Forgets about self without running its destructor. Read more
Sourceยง

fn mem_replace(&mut self, other: Self) -> Self
where Self: Sized,

Replaces self with other, returning the previous value of self. Read more
Sourceยง

fn mem_take(&mut self) -> Self
where Self: Default,

Replaces self with its default value, returning the previous value of self. Read more
Sourceยง

fn mem_swap(&mut self, other: &mut Self)
where Self: Sized,

Swaps the value of self and other without deinitializing either one. Read more
Sourceยง

unsafe fn mem_zeroed<T>() -> T

Available on crate feature unsafe_layout only.
Returns the value of type T represented by the all-zero byte-pattern. Read more
Sourceยง

unsafe fn mem_transmute_copy<Src, Dst>(src: &Src) -> Dst

Available on crate feature unsafe_layout only.
Returns the value of type T represented by the all-zero byte-pattern. Read more
Sourceยง

fn mem_as_bytes(&self) -> &[u8] โ“˜
where Self: Sync + Unpin,

Available on crate feature unsafe_slice only.
View a Sync + Unpin self as &[u8]. Read more
Sourceยง

fn mem_as_bytes_mut(&mut self) -> &mut [u8] โ“˜
where Self: Sync + Unpin,

Available on crate feature unsafe_slice only.
View a Sync + Unpin self as &mut [u8]. Read more
Sourceยง

impl<T> From<T> for T

Sourceยง

fn from(t: T) -> T

Returns the argument unchanged.

ยง

impl<'py, T> FromPyObjectBound<'_, 'py> for T
where T: FromPyObject<'py>,

ยง

fn from_py_object_bound(ob: Borrowed<'_, 'py, PyAny>) -> Result<T, PyErr> โ“˜

Extracts Self from the bound smart pointer obj. Read more
ยง

impl<S> FromSample<S> for S

ยง

fn from_sample_(s: S) -> S

Sourceยง

impl<T> Hook for T

Sourceยง

fn hook_ref<F>(self, f: F) -> Self
where F: FnOnce(&Self),

Applies a function which takes the parameter by shared reference, and then returns the (possibly) modified owned value. Read more
Sourceยง

fn hook_mut<F>(self, f: F) -> Self
where F: FnOnce(&mut Self),

Applies a function which takes the parameter by exclusive reference, and then returns the (possibly) modified owned value. Read more
ยง

impl<T> Instrument for T

ยง

fn instrument(self, span: Span) -> Instrumented<Self> โ“˜

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
ยง

fn in_current_span(self) -> Instrumented<Self> โ“˜

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Sourceยง

impl<T, U> Into<U> for T
where U: From<T>,

Sourceยง

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Sourceยง

impl<T> IntoEither for T

Sourceยง

fn into_either(self, into_left: bool) -> Either<Self, Self> โ“˜

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Sourceยง

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> โ“˜
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
ยง

impl<'py, T> IntoPyObjectExt<'py> for T
where T: IntoPyObject<'py>,

ยง

fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr> โ“˜

Converts self into an owned Python object, dropping type information.
ยง

fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr> โ“˜

Converts self into an owned Python object, dropping type information and unbinding it from the 'py lifetime.
ยง

fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr> โ“˜

Converts self into a Python object. Read more
ยง

impl<F, T> IntoSample<T> for F
where T: FromSample<F>,

ยง

fn into_sample(self) -> T

ยง

impl<T> LayoutRaw for T

ยง

fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError> โ“˜

Returns the layout of the type.
ยง

impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
where T: SharedNiching<N1, N2>, N1: Niching<T>, N2: Niching<T>,

ยง

unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool

Returns whether the given value has been niched. Read more
ยง

fn resolve_niched(out: Place<NichedOption<T, N1>>)

Writes data to out indicating that a T is niched.
ยง

impl<T> Pointable for T

ยง

const ALIGN: usize

The alignment of pointer.
ยง

type Init = T

The type for initializers.
ยง

unsafe fn init(init: <T as Pointable>::Init) -> usize โ“˜

Initializes a with the given initializer. Read more
ยง

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
ยง

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
ยง

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
ยง

impl<T> Pointee for T

ยง

type Metadata = ()

The metadata type for pointers and references to this type.
ยง

impl<T> PyErrArguments for T
where T: for<'py> IntoPyObject<'py> + Send + Sync,

ยง

fn arguments(self, py: Python<'_>) -> Py<PyAny>

Arguments for exception
Sourceยง

impl<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Sourceยง

type Target = T

๐Ÿ”ฌThis is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
Sourceยง

impl<T> ToOwned for T
where T: Clone,

Sourceยง

type Owned = T

The resulting type after obtaining ownership.
Sourceยง

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Sourceยง

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
ยง

impl<T, U> ToSample<U> for T
where U: FromSample<T>,

ยง

fn to_sample_(self) -> U

Sourceยง

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Sourceยง

type Error = Infallible

The type returned in the event of a conversion error.
Sourceยง

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error> โ“˜

Performs the conversion.
Sourceยง

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Sourceยง

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Sourceยง

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error> โ“˜

Performs the conversion.
ยง

impl<T> WithSubscriber for T

ยง

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> โ“˜
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
ยง

fn with_current_subscriber(self) -> WithDispatch<Self> โ“˜

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Sourceยง

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

ยง

impl<S, T> Duplex<S> for T
where T: FromSample<S> + ToSample<S>,

ยง

impl<T> Ungil for T
where T: Send,