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.
§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
impl OsString
Sourcepub unsafe fn from_encoded_bytes_unchecked(bytes: Vec<u8>) -> Self
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub unsafe fn from_encoded_bytes_unchecked(bytes: Vec<u8>) -> Self
os_str_display
#120048)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();
Sourcepub fn as_os_str(&self) -> &OsStr
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn as_os_str(&self) -> &OsStr
os_str_display
#120048)Sourcepub fn into_encoded_bytes(self) -> Vec<u8> ⓘ
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn into_encoded_bytes(self) -> Vec<u8> ⓘ
os_str_display
#120048)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.
Sourcepub fn into_string(self) -> Result<String, OsString>
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn into_string(self) -> Result<String, OsString>
os_str_display
#120048)Sourcepub fn push<T: AsRef<OsStr>>(&mut self, s: T)
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn push<T: AsRef<OsStr>>(&mut self, s: T)
os_str_display
#120048)Sourcepub fn with_capacity(capacity: usize) -> OsString
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn with_capacity(capacity: usize) -> OsString
os_str_display
#120048)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
Sourcepub fn clear(&mut self)
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn clear(&mut self)
os_str_display
#120048)Truncates the OsString
to zero length.
§Examples
Sourcepub fn capacity(&self) -> usize
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn capacity(&self) -> usize
os_str_display
#120048)Returns the capacity this OsString
can hold without reallocating.
See the main OsString
documentation information about encoding and capacity units.
§Examples
Sourcepub fn reserve(&mut self, additional: usize)
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn reserve(&mut self, additional: usize)
os_str_display
#120048)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
Sourcepub fn try_reserve(&mut self, additional: usize) -> Result<(), TryReserveError>
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn try_reserve(&mut self, additional: usize) -> Result<(), TryReserveError>
os_str_display
#120048)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)
}
Sourcepub fn reserve_exact(&mut self, additional: usize)
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn reserve_exact(&mut self, additional: usize)
os_str_display
#120048)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
Sourcepub fn try_reserve_exact(
&mut self,
additional: usize,
) -> Result<(), TryReserveError>
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn try_reserve_exact( &mut self, additional: usize, ) -> Result<(), TryReserveError>
os_str_display
#120048)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)
}
Sourcepub fn shrink_to_fit(&mut self)
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn shrink_to_fit(&mut self)
os_str_display
#120048)Shrinks the capacity of the OsString
to match its length.
See the main OsString
documentation information about encoding and capacity units.
§Examples
Sourcepub fn shrink_to(&mut self, min_capacity: usize)
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn shrink_to(&mut self, min_capacity: usize)
os_str_display
#120048)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
Sourcepub fn into_boxed_os_str(self) -> Box<OsStr>
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn into_boxed_os_str(self) -> Box<OsStr>
os_str_display
#120048)Sourcepub fn leak<'a>(self) -> &'a mut OsStr
🔬This is a nightly-only experimental API. (os_string_pathbuf_leak
#125965)
pub fn leak<'a>(self) -> &'a mut OsStr
os_string_pathbuf_leak
#125965)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.
Methods from Deref<Target = OsStr>§
Sourcepub fn to_str(&self) -> Option<&str>
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn to_str(&self) -> Option<&str>
os_str_display
#120048)Sourcepub fn to_string_lossy(&self) -> Cow<'_, str>
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn to_string_lossy(&self) -> Cow<'_, str>
os_str_display
#120048)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");
}
Sourcepub fn to_os_string(&self) -> OsString
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn to_os_string(&self) -> OsString
os_str_display
#120048)Sourcepub fn is_empty(&self) -> bool
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn is_empty(&self) -> bool
os_str_display
#120048)Checks whether the OsStr
is empty.
§Examples
Sourcepub fn len(&self) -> usize
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn len(&self) -> usize
os_str_display
#120048)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
Sourcepub fn as_encoded_bytes(&self) -> &[u8] ⓘ
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn as_encoded_bytes(&self) -> &[u8] ⓘ
os_str_display
#120048)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.
Sourcepub fn slice_encoded_bytes<R: RangeBounds<usize>>(&self, range: R) -> &Self
🔬This is a nightly-only experimental API. (os_str_slice
#118485)
pub fn slice_encoded_bytes<R: RangeBounds<usize>>(&self, range: R) -> &Self
os_str_slice
#118485)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");
}
Sourcepub fn make_ascii_lowercase(&mut self)
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn make_ascii_lowercase(&mut self)
os_str_display
#120048)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
Sourcepub fn make_ascii_uppercase(&mut self)
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn make_ascii_uppercase(&mut self)
os_str_display
#120048)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
Sourcepub fn to_ascii_lowercase(&self) -> OsString
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn to_ascii_lowercase(&self) -> OsString
os_str_display
#120048)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
Sourcepub fn to_ascii_uppercase(&self) -> OsString
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn to_ascii_uppercase(&self) -> OsString
os_str_display
#120048)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
Sourcepub fn is_ascii(&self) -> bool
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn is_ascii(&self) -> bool
os_str_display
#120048)Checks if all characters in this string are within the ASCII range.
§Examples
Sourcepub fn eq_ignore_ascii_case<S: AsRef<OsStr>>(&self, other: S) -> bool
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn eq_ignore_ascii_case<S: AsRef<OsStr>>(&self, other: S) -> bool
os_str_display
#120048)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
Sourcepub fn display(&self) -> Display<'_>
🔬This is a nightly-only experimental API. (os_str_display
#120048)
pub fn display(&self) -> Display<'_>
os_str_display
#120048)Trait Implementations§
1.52.0 · Source§impl<'a> Extend<&'a OsStr> for OsString
impl<'a> Extend<&'a OsStr> for OsString
Source§fn extend<T: IntoIterator<Item = &'a OsStr>>(&mut self, iter: T)
fn extend<T: IntoIterator<Item = &'a OsStr>>(&mut self, iter: T)
Source§fn extend_one(&mut self, item: A)
fn extend_one(&mut self, item: A)
extend_one
#72631)1.52.0 · Source§impl<'a> Extend<Cow<'a, OsStr>> for OsString
impl<'a> Extend<Cow<'a, OsStr>> for OsString
1.52.0 · Source§impl Extend<OsString> for OsString
impl Extend<OsString> for OsString
Source§fn extend<T: IntoIterator<Item = OsString>>(&mut self, iter: T)
fn extend<T: IntoIterator<Item = OsString>>(&mut self, iter: T)
Source§fn extend_one(&mut self, item: A)
fn extend_one(&mut self, item: A)
extend_one
#72631)