devela::_dep::pyo3::types

Trait PyStringMethods

pub trait PyStringMethods<'py>: Sealed {
    // Required methods
    fn to_str(&self) -> Result<&str, PyErr> ;
    fn to_cow(&self) -> Result<Cow<'_, str>, PyErr> ;
    fn to_string_lossy(&self) -> Cow<'_, str>;
    fn encode_utf8(&self) -> Result<Bound<'py, PyBytes>, PyErr> ;
    unsafe fn data(&self) -> Result<PyStringData<'_>, PyErr> ;
}
Available on crate features dep_pyo3 and std only.
Expand description

Implementation of functionality for PyString.

These methods are defined for the Bound<'py, PyString> smart pointer, so to use method call syntax these methods are separated into a trait, because stable Rust does not yet support arbitrary_self_types.

Required Methods§

fn to_str(&self) -> Result<&str, PyErr>

Gets the Python string as a Rust UTF-8 string slice.

Returns a UnicodeEncodeError if the input is not valid unicode (containing unpaired surrogates).

fn to_cow(&self) -> Result<Cow<'_, str>, PyErr>

Converts the PyString into a Rust string, avoiding copying when possible.

Returns a UnicodeEncodeError if the input is not valid unicode (containing unpaired surrogates).

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

Converts the PyString into a Rust string.

Unpaired surrogates invalid UTF-8 sequences are replaced with U+FFFD REPLACEMENT CHARACTER.

fn encode_utf8(&self) -> Result<Bound<'py, PyBytes>, PyErr>

Encodes this string as a Python bytes object, using UTF-8 encoding.

unsafe fn data(&self) -> Result<PyStringData<'_>, PyErr>

Obtains the raw data backing the Python string.

If the Python string object was created through legacy APIs, its internal storage format will be canonicalized before data is returned.

§Safety

This function implementation relies on manually decoding a C bitfield. In practice, this works well on common little-endian architectures such as x86_64, where the bitfield has a common representation (even if it is not part of the C spec). The PyO3 CI tests this API on x86_64 platforms.

By using this API, you accept responsibility for testing that PyStringData behaves as expected on the targets where you plan to distribute your software.

Implementors§

§

impl<'py> PyStringMethods<'py> for Bound<'py, PyString>