Skip to main content

PyStr

Struct PyStr 

Source
pub struct PyStr { /* private fields */ }

Implementations§

Source§

impl PyStr

Source

pub unsafe fn new_ascii_unchecked(bytes: Vec<u8>) -> Self

§Safety

Given bytes must be ascii

Source

pub fn new_ref(zelf: impl Into<Self>, ctx: &Context) -> PyRef<Self>

👎Deprecated:

use PyStr::from(…).into_ref() instead

Source

pub const fn as_wtf8(&self) -> &Wtf8

Source

pub const fn as_bytes(&self) -> &[u8]

Source

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

Source

pub fn expect_str(&self) -> &str

Returns &str

§Panic

If the string contains surrogates.

Source

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

Source

pub const fn kind(&self) -> StrKind

Source

pub fn as_str_kind(&self) -> PyKindStr<'_>

Source

pub const fn is_utf8(&self) -> bool

Source

pub fn try_as_utf8<'a>(&'a self, vm: &VirtualMachine) -> PyResult<&'a PyUtf8Str>

Source§

impl PyStr

Source

pub fn byte_len(&self) -> usize

Source

pub fn is_empty(&self) -> bool

Source

pub fn char_len(&self) -> usize

Source

pub const fn isascii(&self) -> bool

Source

pub fn isidentifier(&self) -> bool

Trait Implementations§

Source§

impl AsMapping for PyStr

Source§

fn as_mapping() -> &'static PyMappingMethods

Source§

fn mapping_downcast(mapping: PyMapping<'_>) -> &Py<Self>

Source§

fn extend_slots(slots: &mut PyTypeSlots)

Source§

const __OWN_METHOD_DEFS: &'static [PyMethodDef] = _

Source§

fn __extend_py_class(ctx: &'static Context, class: &'static Py<PyType>)

Source§

fn __extend_slots(slots: &mut PyTypeSlots)

Source§

impl AsNumber for PyStr

Source§

fn as_number() -> &'static PyNumberMethods

Source§

fn extend_slots(slots: &mut PyTypeSlots)

Source§

fn clone_exact(_zelf: &Py<Self>, _vm: &VirtualMachine) -> PyRef<Self>

Source§

fn number_downcast(num: PyNumber<'_>) -> &Py<Self>

Source§

fn number_downcast_exact(num: PyNumber<'_>, vm: &VirtualMachine) -> PyRef<Self>

Source§

const __OWN_METHOD_DEFS: &'static [PyMethodDef] = _

Source§

fn __extend_py_class(ctx: &'static Context, class: &'static Py<PyType>)

Source§

fn __extend_slots(slots: &mut PyTypeSlots)

Source§

impl AsRef<Wtf8> for PyStr

Source§

fn as_ref(&self) -> &Wtf8

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl AsRef<str> for PyStr

Source§

fn as_ref(&self) -> &str

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl AsSequence for PyStr

Source§

impl Comparable for PyStr

Source§

impl Constructor for PyStr

Source§

type Args = StrArgs

Source§

fn slot_new( cls: PyTypeRef, func_args: FuncArgs, vm: &VirtualMachine, ) -> PyResult

The type slot for __new__. Override this only when you need special behavior beyond simple payload creation.
Source§

fn py_new( _cls: &Py<PyType>, args: Self::Args, vm: &VirtualMachine, ) -> PyResult<Self>

Creates the payload for this type. In most cases, just implement this method and let the default slot_new handle wrapping with the correct type.
Source§

const __OWN_METHOD_DEFS: &'static [PyMethodDef] = _

Source§

fn __extend_py_class(ctx: &'static Context, class: &'static Py<PyType>)

Source§

fn __extend_slots(slots: &mut PyTypeSlots)

Source§

impl Debug for PyStr

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for PyStr

Source§

fn default() -> Self

Returns the “default value” for a type. Read more
Source§

impl Display for PyStr

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'a> From<&'a AsciiStr> for PyStr

Source§

fn from(s: &'a AsciiStr) -> Self

Converts to this type from the input type.
Source§

impl<'a> From<&'a Wtf8> for PyStr

Source§

fn from(s: &'a Wtf8) -> Self

Converts to this type from the input type.
Source§

impl<'a> From<&'a str> for PyStr

Source§

fn from(s: &'a str) -> Self

Converts to this type from the input type.
Source§

impl From<AsciiChar> for PyStr

Source§

fn from(ch: AsciiChar) -> Self

Converts to this type from the input type.
Source§

impl From<AsciiString> for PyStr

Source§

fn from(s: AsciiString) -> Self

Converts to this type from the input type.
Source§

impl From<Box<AsciiStr>> for PyStr

Source§

fn from(s: Box<AsciiStr>) -> Self

Converts to this type from the input type.
Source§

impl From<Box<Wtf8>> for PyStr

Source§

fn from(value: Box<Wtf8>) -> Self

Converts to this type from the input type.
Source§

impl From<Box<str>> for PyStr

Source§

fn from(value: Box<str>) -> Self

Converts to this type from the input type.
Source§

impl From<CodePoint> for PyStr

Source§

fn from(ch: CodePoint) -> Self

Converts to this type from the input type.
Source§

impl<'a> From<Cow<'a, str>> for PyStr

Source§

fn from(s: Cow<'a, str>) -> Self

Converts to this type from the input type.
Source§

impl From<StrData> for PyStr

Source§

fn from(data: StrData) -> Self

Converts to this type from the input type.
Source§

impl From<String> for PyStr

Source§

fn from(s: String) -> Self

Converts to this type from the input type.
Source§

impl From<Wtf8Buf> for PyStr

Source§

fn from(w: Wtf8Buf) -> Self

Converts to this type from the input type.
Source§

impl From<char> for PyStr

Source§

fn from(ch: char) -> Self

Converts to this type from the input type.
Source§

impl Hashable for PyStr

Source§

impl Iterable for PyStr

Source§

impl MaybeTraverse for PyStr

Source§

const HAS_TRAVERSE: bool = false

if is traceable, will be used by vtable to determine
Source§

const HAS_CLEAR: bool = false

if has clear implementation for circular reference resolution (tp_clear)
Source§

fn try_traverse(&self, tracer_fn: &mut TraverseFn<'_>)

Source§

fn try_clear(&mut self, out: &mut Vec<PyObjectRef>)

Source§

impl PyClassDef for PyStr

Source§

const NAME: &'static str = "str"

Source§

const MODULE_NAME: Option<&'static str> = None

Source§

const TP_NAME: &'static str = "str"

Source§

const DOC: Option<&'static str>

Source§

const BASICSIZE: usize

Source§

const UNHASHABLE: bool = false

Source§

type Base = PyBaseObject

Source§

const ITEMSIZE: usize = 0

Source§

impl PyClassImpl for PyStr

Source§

const TP_FLAGS: PyTypeFlags

Source§

const METHOD_DEFS: &'static [PyMethodDef]

Source§

fn impl_extend_class(ctx: &'static Context, class: &'static Py<PyType>)

Source§

fn extend_slots(slots: &mut PyTypeSlots)

Source§

fn extend_class(ctx: &'static Context, class: &'static Py<PyType>)
where Self: Sized,

Source§

fn make_static_type() -> PyTypeRef
where Self: StaticType + Sized,

Source§

fn make_slots() -> PyTypeSlots

Source§

impl PyPayload for PyStr

Source§

fn class(ctx: &Context) -> &'static Py<PyType>

Source§

const PAYLOAD_TYPE_ID: TypeId = _

Source§

unsafe fn validate_downcastable_from(_obj: &PyObject) -> bool

Safety Read more
Source§

fn try_downcast_from(obj: &PyObject, vm: &VirtualMachine) -> PyResult<()>

Source§

const HAS_FREELIST: bool = false

Whether this type has a freelist. Types with freelists require immediate (non-deferred) GC untracking during dealloc to prevent race conditions when the object is reused.
Source§

const MAX_FREELIST: usize = 0

Maximum number of objects to keep in the freelist.
Source§

unsafe fn freelist_push(_obj: *mut PyObject) -> bool

Try to push a dead object onto this type’s freelist for reuse. Returns true if the object was stored (caller must NOT free the memory). Called before tp_clear, so the payload is still intact. Read more
Source§

unsafe fn freelist_pop(_payload: &Self) -> Option<NonNull<PyObject>>

Try to pop a pre-allocated object from this type’s freelist. The returned pointer still has the old payload; the caller must reinitialize ref_count, gc_bits, and payload. Read more
Source§

fn into_pyobject(self, vm: &VirtualMachine) -> PyObjectRef
where Self: Debug,

Source§

fn _into_ref(self, cls: PyTypeRef, ctx: &Context) -> PyRef<Self>
where Self: Debug,

Source§

fn into_exact_ref(self, ctx: &Context) -> PyRefExact<Self>
where Self: Debug,

Source§

fn into_ref(self, ctx: &Context) -> PyRef<Self>
where Self: Debug,

Source§

fn into_ref_with_type( self, vm: &VirtualMachine, cls: PyTypeRef, ) -> PyResult<PyRef<Self>>
where Self: Debug,

Source§

impl Representable for PyStr

Source§

impl SliceableSequenceOp for PyStr

Source§

type Item = CodePoint

Source§

type Sliced = PyStr

Source§

fn do_get(&self, index: usize) -> Self::Item

Source§

fn do_slice(&self, range: Range<usize>) -> Self::Sliced

Source§

fn do_slice_reverse(&self, range: Range<usize>) -> Self::Sliced

Source§

fn do_stepped_slice(&self, range: Range<usize>, step: usize) -> Self::Sliced

Source§

fn do_stepped_slice_reverse( &self, range: Range<usize>, step: usize, ) -> Self::Sliced

Source§

fn empty() -> Self::Sliced

Source§

fn len(&self) -> usize

Source§

fn wrap_index(&self, p: isize) -> Option<usize>

Source§

fn saturate_index(&self, p: isize) -> usize

Source§

fn getitem_by_slice( &self, _vm: &VirtualMachine, slice: SaturatedSlice, ) -> PyResult<Self::Sliced>

Source§

fn getitem_by_index( &self, vm: &VirtualMachine, index: isize, ) -> PyResult<Self::Item>

Source§

impl StaticType for PyStr

Source§

impl ToCString for PyStr

Source§

impl Wtf8Concat for PyStr

Source§

fn fmt_wtf8(&self, buf: &mut Wtf8Buf)

Auto Trait Implementations§

§

impl !Freeze for PyStr

§

impl !RefUnwindSafe for PyStr

§

impl Send for PyStr

§

impl !Sync for PyStr

§

impl Unpin for PyStr

§

impl UnsafeUnpin for PyStr

§

impl UnwindSafe for PyStr

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
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> Candidate for T
where T: AsRef<str>,

Source§

fn display(&self) -> &str

Text to display when listing alternatives.
Source§

fn replacement(&self) -> &str

Text to insert in line.
Source§

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

Source§

fn exact_from(value: T) -> U

Source§

impl<T, U> ExactInto<U> for T
where U: ExactFrom<T>,

Source§

fn exact_into(self) -> U

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Hint for T
where T: AsRef<str>,

Source§

fn display(&self) -> &str

Text to display when hint is active
Source§

fn completion(&self) -> Option<&str>

Text to insert in line when right arrow is pressed
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
Source§

impl<T, U> OverflowingInto<U> for T
where U: OverflowingFrom<T>,

Source§

impl<T, U> RoundingInto<U> for T
where U: RoundingFrom<T>,

Source§

impl<T, U> SaturatingInto<U> for T
where U: SaturatingFrom<T>,

Source§

impl<T> ToCompactString for T
where T: Display,

Source§

impl<T> ToDebugString for T
where T: Debug,

Source§

fn to_debug_string(&self) -> String

Returns the String produced by Ts Debug implementation.

§Examples
use malachite_base::strings::ToDebugString;

assert_eq!([1, 2, 3].to_debug_string(), "[1, 2, 3]");
assert_eq!(
    [vec![2, 3], vec![], vec![4]].to_debug_string(),
    "[[2, 3], [], [4]]"
);
assert_eq!(Some(5).to_debug_string(), "Some(5)");
Source§

impl<T> ToPyObject for T
where T: PyPayload + Debug,

Source§

impl<T> ToPyResult for T
where T: ToPyObject,

Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
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.
Source§

impl<T, U> WrappingInto<U> for T
where U: WrappingFrom<T>,

Source§

fn wrapping_into(self) -> U

Source§

impl<T> PyObjectPayload for T
where T: PyPayload + Debug + 'static,

Source§

impl<T> PyThreadingConstraint for T