Struct Py
pub struct Py<T>(/* private fields */);
dep_pyo3
and std
only.Expand description
A GIL-independent reference to an object allocated on the Python heap.
This type does not auto-dereference to the inner object because you must prove you hold the GIL to access it. Instead, call one of its methods to access the inner object:
Py::bind
orPy::into_bound
, to borrow a GIL-bound reference to the contained object.Py::borrow
,Py::try_borrow
,Py::borrow_mut
, orPy::try_borrow_mut
,
to get a (mutable) reference to a contained pyclass, using a scheme similar to std’s RefCell
.
See the
guide entry
for more information.
- You can call methods directly on
Py
withPy::call_bound
,Py::call_method_bound
and friends.
These require passing in the Python<'py>
token but are otherwise similar to the corresponding
methods on PyAny
.
§Example: Storing Python objects in #[pyclass]
structs
Usually Bound<'py, T>
is recommended for interacting with Python objects as its lifetime 'py
is an association to the GIL and that enables many operations to be done as efficiently as possible.
However, #[pyclass]
structs cannot carry a lifetime, so Py<T>
is the only way to store
a Python object in a #[pyclass]
struct.
For example, this won’t compile:
#[pyclass]
struct Foo<'py> {
inner: Bound<'py, PyDict>,
}
impl Foo {
fn new() -> Foo {
let foo = Python::with_gil(|py| {
// `py` will only last for this scope.
// `Bound<'py, PyDict>` inherits the GIL lifetime from `py` and
// so won't be able to outlive this closure.
let dict: Bound<'_, PyDict> = PyDict::new(py);
// because `Foo` contains `dict` its lifetime
// is now also tied to `py`.
Foo { inner: dict }
});
// Foo is no longer valid.
// Returning it from this function is a 💥 compiler error 💥
foo
}
}
Py
<T>
can be used to get around this by converting dict
into a GIL-independent reference:
use pyo3::prelude::*;
use pyo3::types::PyDict;
#[pyclass]
struct Foo {
inner: Py<PyDict>,
}
#[pymethods]
impl Foo {
#[new]
fn __new__() -> Foo {
Python::with_gil(|py| {
let dict: Py<PyDict> = PyDict::new(py).unbind();
Foo { inner: dict }
})
}
}
This can also be done with other pyclasses:
use pyo3::prelude::*;
#[pyclass]
struct Bar {/* ... */}
#[pyclass]
struct Foo {
inner: Py<Bar>,
}
#[pymethods]
impl Foo {
#[new]
fn __new__() -> PyResult<Foo> {
Python::with_gil(|py| {
let bar: Py<Bar> = Py::new(py, Bar {})?;
Ok(Foo { inner: bar })
})
}
}
§Example: Shared ownership of Python objects
Py<T>
can be used to share ownership of a Python object, similar to std’s Rc
<T>
.
As with Rc
<T>
, cloning it increases its reference count rather than duplicating
the underlying object.
This can be done using either Py::clone_ref
or Py
<T>
’s Clone
trait implementation.
Py::clone_ref
will be faster if you happen to be already holding the GIL.
use pyo3::prelude::*;
use pyo3::types::PyDict;
Python::with_gil(|py| {
let first: Py<PyDict> = PyDict::new(py).unbind();
// All of these are valid syntax
let second = Py::clone_ref(&first, py);
let third = first.clone_ref(py);
#[cfg(feature = "py-clone")]
let fourth = Py::clone(&first);
#[cfg(feature = "py-clone")]
let fifth = first.clone();
// Disposing of our original `Py<PyDict>` just decrements the reference count.
drop(first);
// They all point to the same object
assert!(second.is(&third));
#[cfg(feature = "py-clone")]
assert!(fourth.is(&fifth));
#[cfg(feature = "py-clone")]
assert!(second.is(&fourth));
});
§Preventing reference cycles
It is easy to accidentally create reference cycles using Py
<T>
.
The Python interpreter can break these reference cycles within pyclasses if they
integrate with the garbage collector. If your pyclass contains other Python
objects you should implement it to avoid leaking memory.
§A note on Python reference counts
Dropping a Py
<T>
will eventually decrease Python’s reference count
of the pointed-to variable, allowing Python’s garbage collector to free
the associated memory, but this may not happen immediately. This is
because a Py
<T>
can be dropped at any time, but the Python reference
count can only be modified when the GIL is held.
If a Py
<T>
is dropped while its thread happens to be holding the
GIL then the Python reference count will be decreased immediately.
Otherwise, the reference count will be decreased the next time the GIL is
reacquired.
If you happen to be already holding the GIL, Py::drop_ref
will decrease
the Python reference count immediately and will execute slightly faster than
relying on implicit Drop
s.
§A note on Send
and Sync
Accessing this object is thread-safe, since any access to its API requires a Python<'py>
token.
As you can only get this by acquiring the GIL, Py<...>
implements Send
and Sync
.
Implementations§
§impl<T> Py<T>where
T: PyClass,
impl<T> Py<T>where
T: PyClass,
pub fn new(
py: Python<'_>,
value: impl Into<PyClassInitializer<T>>,
) -> Result<Py<T>, PyErr> ⓘ
pub fn new( py: Python<'_>, value: impl Into<PyClassInitializer<T>>, ) -> Result<Py<T>, PyErr> ⓘ
Creates a new instance Py<T>
of a #[pyclass]
on the Python heap.
§Examples
use pyo3::prelude::*;
#[pyclass]
struct Foo {/* fields omitted */}
let foo = Python::with_gil(|py| -> PyResult<_> {
let foo: Py<Foo> = Py::new(py, Foo {})?;
Ok(foo)
})?;
§impl<T> Py<T>
impl<T> Py<T>
pub fn as_ptr(&self) -> *mut PyObject
pub fn as_ptr(&self) -> *mut PyObject
Returns the raw FFI pointer represented by self.
§Safety
Callers are responsible for ensuring that the pointer does not outlive self.
The reference is borrowed; callers should not decrease the reference count when they are finished with the pointer.
pub fn into_ptr(self) -> *mut PyObject
pub fn into_ptr(self) -> *mut PyObject
Returns an owned raw FFI pointer represented by self.
§Safety
The reference is owned; when finished the caller should either transfer ownership
of the pointer or decrease the reference count (e.g. with pyo3::ffi::Py_DecRef
).
§impl<T> Py<T>where
T: PyClass,
impl<T> Py<T>where
T: PyClass,
pub fn borrow<'py>(&'py self, py: Python<'py>) -> PyRef<'py, T>
pub fn borrow<'py>(&'py self, py: Python<'py>) -> PyRef<'py, T>
Immutably borrows the value T
.
This borrow lasts while the returned PyRef
exists.
Multiple immutable borrows can be taken out at the same time.
For frozen classes, the simpler get
is available.
Equivalent to self.bind(py).borrow()
- see Bound::borrow
.
§Examples
#[pyclass]
struct Foo {
inner: u8,
}
Python::with_gil(|py| -> PyResult<()> {
let foo: Py<Foo> = Py::new(py, Foo { inner: 73 })?;
let inner: &u8 = &foo.borrow(py).inner;
assert_eq!(*inner, 73);
Ok(())
})?;
§Panics
Panics if the value is currently mutably borrowed. For a non-panicking variant, use
try_borrow
.
pub fn borrow_mut<'py>(&'py self, py: Python<'py>) -> PyRefMut<'py, T>where
T: PyClass<Frozen = False>,
pub fn borrow_mut<'py>(&'py self, py: Python<'py>) -> PyRefMut<'py, T>where
T: PyClass<Frozen = False>,
Mutably borrows the value T
.
This borrow lasts while the returned PyRefMut
exists.
Equivalent to self.bind(py).borrow_mut()
- see Bound::borrow_mut
.
§Examples
#[pyclass]
struct Foo {
inner: u8,
}
Python::with_gil(|py| -> PyResult<()> {
let foo: Py<Foo> = Py::new(py, Foo { inner: 73 })?;
foo.borrow_mut(py).inner = 35;
assert_eq!(foo.borrow(py).inner, 35);
Ok(())
})?;
§Panics
Panics if the value is currently borrowed. For a non-panicking variant, use
try_borrow_mut
.
pub fn try_borrow<'py>(
&'py self,
py: Python<'py>,
) -> Result<PyRef<'py, T>, PyBorrowError> ⓘ
pub fn try_borrow<'py>( &'py self, py: Python<'py>, ) -> Result<PyRef<'py, T>, PyBorrowError> ⓘ
Attempts to immutably borrow the value T
, returning an error if the value is currently mutably borrowed.
The borrow lasts while the returned PyRef
exists.
This is the non-panicking variant of borrow
.
For frozen classes, the simpler get
is available.
Equivalent to self.bind(py).try_borrow()
- see Bound::try_borrow
.
pub fn try_borrow_mut<'py>(
&'py self,
py: Python<'py>,
) -> Result<PyRefMut<'py, T>, PyBorrowMutError> ⓘwhere
T: PyClass<Frozen = False>,
pub fn try_borrow_mut<'py>(
&'py self,
py: Python<'py>,
) -> Result<PyRefMut<'py, T>, PyBorrowMutError> ⓘwhere
T: PyClass<Frozen = False>,
Attempts to mutably borrow the value T
, returning an error if the value is currently borrowed.
The borrow lasts while the returned PyRefMut
exists.
This is the non-panicking variant of borrow_mut
.
Equivalent to self.bind(py).try_borrow_mut()
- see Bound::try_borrow_mut
.
pub fn get(&self) -> &T
pub fn get(&self) -> &T
Provide an immutable borrow of the value T
without acquiring the GIL.
This is available if the class is [frozen
][macro@crate::pyclass] and Sync
.
§Examples
use std::sync::atomic::{AtomicUsize, Ordering};
#[pyclass(frozen)]
struct FrozenCounter {
value: AtomicUsize,
}
let cell = Python::with_gil(|py| {
let counter = FrozenCounter { value: AtomicUsize::new(0) };
Py::new(py, counter).unwrap()
});
cell.get().value.fetch_add(1, Ordering::Relaxed);
§impl<T> Py<T>
impl<T> Py<T>
pub fn bind<'py>(&self, _py: Python<'py>) -> &Bound<'py, T>
pub fn bind<'py>(&self, _py: Python<'py>) -> &Bound<'py, T>
Attaches this Py
to the given Python context, allowing access to further Python APIs.
pub fn into_bound(self, py: Python<'_>) -> Bound<'_, T>
pub fn into_bound(self, py: Python<'_>) -> Bound<'_, T>
Same as bind
but takes ownership of self
.
pub fn bind_borrowed<'a, 'py>(&'a self, py: Python<'py>) -> Borrowed<'a, 'py, T>
pub fn bind_borrowed<'a, 'py>(&'a self, py: Python<'py>) -> Borrowed<'a, 'py, T>
Same as bind
but produces a Borrowed<T>
instead of a Bound<T>
.
pub fn is<U>(&self, o: &U) -> boolwhere
U: AsPyPointer,
pub fn is<U>(&self, o: &U) -> boolwhere
U: AsPyPointer,
Returns whether self
and other
point to the same object. To compare
the equality of two objects (the ==
operator), use eq
.
This is equivalent to the Python expression self is other
.
pub fn get_refcnt(&self, _py: Python<'_>) -> isize ⓘ
pub fn get_refcnt(&self, _py: Python<'_>) -> isize ⓘ
Gets the reference count of the ffi::PyObject
pointer.
pub fn clone_ref(&self, _py: Python<'_>) -> Py<T>
pub fn clone_ref(&self, _py: Python<'_>) -> Py<T>
Makes a clone of self
.
This creates another pointer to the same object, increasing its reference count.
You should prefer using this method over Clone
if you happen to be holding the GIL already.
§Examples
use pyo3::prelude::*;
use pyo3::types::PyDict;
Python::with_gil(|py| {
let first: Py<PyDict> = PyDict::new(py).unbind();
let second = Py::clone_ref(&first, py);
// Both point to the same object
assert!(first.is(&second));
});
pub fn drop_ref(self, py: Python<'_>)
pub fn drop_ref(self, py: Python<'_>)
Drops self
and immediately decreases its reference count.
This method is a micro-optimisation over Drop
if you happen to be holding the GIL
already.
Note that if you are using Bound
, you do not need to use Self::drop_ref
since
Bound
guarantees that the GIL is held.
§Examples
use pyo3::prelude::*;
use pyo3::types::PyDict;
Python::with_gil(|py| {
let object: Py<PyDict> = PyDict::new(py).unbind();
// some usage of object
object.drop_ref(py);
});
pub fn is_none(&self, _py: Python<'_>) -> bool
pub fn is_none(&self, _py: Python<'_>) -> bool
Returns whether the object is considered to be None.
This is equivalent to the Python expression self is None
.
pub fn is_truthy(&self, py: Python<'_>) -> Result<bool, PyErr> ⓘ
pub fn is_truthy(&self, py: Python<'_>) -> Result<bool, PyErr> ⓘ
Returns whether the object is considered to be true.
This applies truth value testing equivalent to the Python expression bool(self)
.
pub fn extract<'a, 'py, D>(&'a self, py: Python<'py>) -> Result<D, PyErr> ⓘwhere
'py: 'a,
D: FromPyObjectBound<'a, 'py>,
pub fn extract<'a, 'py, D>(&'a self, py: Python<'py>) -> Result<D, PyErr> ⓘwhere
'py: 'a,
D: FromPyObjectBound<'a, 'py>,
Extracts some type from the Python object.
This is a wrapper function around FromPyObject::extract()
.
pub fn getattr<'py, N>(
&self,
py: Python<'py>,
attr_name: N,
) -> Result<Py<PyAny>, PyErr> ⓘwhere
N: IntoPyObject<'py, Target = PyString>,
pub fn getattr<'py, N>(
&self,
py: Python<'py>,
attr_name: N,
) -> Result<Py<PyAny>, PyErr> ⓘwhere
N: IntoPyObject<'py, Target = PyString>,
Retrieves an attribute value.
This is equivalent to the Python expression self.attr_name
.
If calling this method becomes performance-critical, the intern!
macro
can be used to intern attr_name
, thereby avoiding repeated temporary allocations of
Python strings.
§Example: intern!
ing the attribute name
#[pyfunction]
fn version(sys: Py<PyModule>, py: Python<'_>) -> PyResult<PyObject> {
sys.getattr(py, intern!(py, "version"))
}
pub fn setattr<'py, N, V>(
&self,
py: Python<'py>,
attr_name: N,
value: V,
) -> Result<(), PyErr> ⓘ
pub fn setattr<'py, N, V>( &self, py: Python<'py>, attr_name: N, value: V, ) -> Result<(), PyErr> ⓘ
Sets an attribute value.
This is equivalent to the Python expression self.attr_name = value
.
To avoid repeated temporary allocations of Python strings, the intern!
macro can be used to intern attr_name
.
§Example: intern!
ing the attribute name
#[pyfunction]
fn set_answer(ob: PyObject, py: Python<'_>) -> PyResult<()> {
ob.setattr(py, intern!(py, "answer"), 42)
}
pub fn call<'py, A>(
&self,
py: Python<'py>,
args: A,
kwargs: Option<&Bound<'py, PyDict>>,
) -> Result<Py<PyAny>, PyErr> ⓘwhere
A: IntoPyObject<'py, Target = PyTuple>,
pub fn call<'py, A>(
&self,
py: Python<'py>,
args: A,
kwargs: Option<&Bound<'py, PyDict>>,
) -> Result<Py<PyAny>, PyErr> ⓘwhere
A: IntoPyObject<'py, Target = PyTuple>,
Calls the object.
This is equivalent to the Python expression self(*args, **kwargs)
.
pub fn call_bound(
&self,
py: Python<'_>,
args: impl IntoPy<Py<PyTuple>>,
kwargs: Option<&Bound<'_, PyDict>>,
) -> Result<Py<PyAny>, PyErr> ⓘ
👎Deprecated since 0.23.0: renamed to Py::call
pub fn call_bound( &self, py: Python<'_>, args: impl IntoPy<Py<PyTuple>>, kwargs: Option<&Bound<'_, PyDict>>, ) -> Result<Py<PyAny>, PyErr> ⓘ
Py::call
Deprecated name for Py::call
.
pub fn call1<'py, N>(
&self,
py: Python<'py>,
args: N,
) -> Result<Py<PyAny>, PyErr> ⓘwhere
N: IntoPyObject<'py, Target = PyTuple>,
pub fn call1<'py, N>(
&self,
py: Python<'py>,
args: N,
) -> Result<Py<PyAny>, PyErr> ⓘwhere
N: IntoPyObject<'py, Target = PyTuple>,
Calls the object with only positional arguments.
This is equivalent to the Python expression self(*args)
.
pub fn call0(&self, py: Python<'_>) -> Result<Py<PyAny>, PyErr> ⓘ
pub fn call0(&self, py: Python<'_>) -> Result<Py<PyAny>, PyErr> ⓘ
Calls the object without arguments.
This is equivalent to the Python expression self()
.
pub fn call_method<'py, N, A>(
&self,
py: Python<'py>,
name: N,
args: A,
kwargs: Option<&Bound<'py, PyDict>>,
) -> Result<Py<PyAny>, PyErr> ⓘ
pub fn call_method<'py, N, A>( &self, py: Python<'py>, name: N, args: A, kwargs: Option<&Bound<'py, PyDict>>, ) -> Result<Py<PyAny>, PyErr> ⓘ
Calls a method on the object.
This is equivalent to the Python expression self.name(*args, **kwargs)
.
To avoid repeated temporary allocations of Python strings, the intern!
macro can be used to intern name
.
pub fn call_method_bound<N, A>(
&self,
py: Python<'_>,
name: N,
args: A,
kwargs: Option<&Bound<'_, PyDict>>,
) -> Result<Py<PyAny>, PyErr> ⓘ
👎Deprecated since 0.23.0: renamed to Py::call_method
pub fn call_method_bound<N, A>( &self, py: Python<'_>, name: N, args: A, kwargs: Option<&Bound<'_, PyDict>>, ) -> Result<Py<PyAny>, PyErr> ⓘ
Py::call_method
Deprecated name for Py::call_method
.
pub fn call_method1<'py, N, A>(
&self,
py: Python<'py>,
name: N,
args: A,
) -> Result<Py<PyAny>, PyErr> ⓘ
pub fn call_method1<'py, N, A>( &self, py: Python<'py>, name: N, args: A, ) -> Result<Py<PyAny>, PyErr> ⓘ
Calls a method on the object with only positional arguments.
This is equivalent to the Python expression self.name(*args)
.
To avoid repeated temporary allocations of Python strings, the intern!
macro can be used to intern name
.
pub fn call_method0<'py, N>(
&self,
py: Python<'py>,
name: N,
) -> Result<Py<PyAny>, PyErr> ⓘwhere
N: IntoPyObject<'py, Target = PyString>,
pub fn call_method0<'py, N>(
&self,
py: Python<'py>,
name: N,
) -> Result<Py<PyAny>, PyErr> ⓘwhere
N: IntoPyObject<'py, Target = PyString>,
Calls a method on the object with no arguments.
This is equivalent to the Python expression self.name()
.
To avoid repeated temporary allocations of Python strings, the intern!
macro can be used to intern name
.
pub unsafe fn from_owned_ptr(py: Python<'_>, ptr: *mut PyObject) -> Py<T>
pub unsafe fn from_owned_ptr(py: Python<'_>, ptr: *mut PyObject) -> Py<T>
pub unsafe fn from_owned_ptr_or_err(
py: Python<'_>,
ptr: *mut PyObject,
) -> Result<Py<T>, PyErr> ⓘ
pub unsafe fn from_owned_ptr_or_err( py: Python<'_>, ptr: *mut PyObject, ) -> Result<Py<T>, PyErr> ⓘ
pub unsafe fn from_owned_ptr_or_opt(
_py: Python<'_>,
ptr: *mut PyObject,
) -> Option<Py<T>> ⓘ
pub unsafe fn from_owned_ptr_or_opt( _py: Python<'_>, ptr: *mut PyObject, ) -> Option<Py<T>> ⓘ
Create a Py<T>
instance by taking ownership of the given FFI pointer.
If ptr
is null then None
is returned.
§Safety
If non-null, ptr
must be a pointer to a Python object of type T.
pub unsafe fn from_borrowed_ptr(py: Python<'_>, ptr: *mut PyObject) -> Py<T>
pub unsafe fn from_borrowed_ptr(py: Python<'_>, ptr: *mut PyObject) -> Py<T>
pub unsafe fn from_borrowed_ptr_or_err(
py: Python<'_>,
ptr: *mut PyObject,
) -> Result<Py<T>, PyErr> ⓘ
pub unsafe fn from_borrowed_ptr_or_err( py: Python<'_>, ptr: *mut PyObject, ) -> Result<Py<T>, PyErr> ⓘ
Create a Py<T>
instance by creating a new reference from the given FFI pointer.
If ptr
is null then the current Python exception is fetched as a PyErr
.
§Safety
ptr
must be a pointer to a Python object of type T.
§impl Py<PyAny>
impl Py<PyAny>
pub fn downcast_bound<'py, T>(
&self,
py: Python<'py>,
) -> Result<&Bound<'py, T>, DowncastError<'_, 'py>> ⓘwhere
T: PyTypeCheck,
pub fn downcast_bound<'py, T>(
&self,
py: Python<'py>,
) -> Result<&Bound<'py, T>, DowncastError<'_, 'py>> ⓘwhere
T: PyTypeCheck,
Downcast this PyObject
to a concrete Python type or pyclass.
Note that you can often avoid downcasting yourself by just specifying the desired type in function or method signatures. However, manual downcasting is sometimes necessary.
For extracting a Rust-only type, see Py::extract
.
§Example: Downcasting to a specific Python object
use pyo3::prelude::*;
use pyo3::types::{PyDict, PyList};
Python::with_gil(|py| {
let any: PyObject = PyDict::new(py).into();
assert!(any.downcast_bound::<PyDict>(py).is_ok());
assert!(any.downcast_bound::<PyList>(py).is_err());
});
§Example: Getting a reference to a pyclass
This is useful if you want to mutate a PyObject
that
might actually be a pyclass.
use pyo3::prelude::*;
#[pyclass]
struct Class {
i: i32,
}
Python::with_gil(|py| {
let class: PyObject = Py::new(py, Class { i: 0 })?.into_any();
let class_bound = class.downcast_bound::<Class>(py)?;
class_bound.borrow_mut().i += 1;
// Alternatively you can get a `PyRefMut` directly
let class_ref: PyRefMut<'_, Class> = class.extract(py)?;
assert_eq!(class_ref.i, 1);
Ok(())
})
pub unsafe fn downcast_bound_unchecked<'py, T>(
&self,
py: Python<'py>,
) -> &Bound<'py, T>
pub unsafe fn downcast_bound_unchecked<'py, T>( &self, py: Python<'py>, ) -> &Bound<'py, T>
Casts the PyObject to a concrete Python object type without checking validity.
§Safety
Callers must ensure that the type is valid or risk type confusion.
§impl Py<PyString>
impl Py<PyString>
pub fn to_str<'a>(&'a self, py: Python<'_>) -> Result<&'a str, PyErr> ⓘ
pub fn to_str<'a>(&'a self, py: Python<'_>) -> Result<&'a 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).
Because str
objects are immutable, the returned slice is independent of
the GIL lifetime.
pub fn to_cow<'a>(&'a self, py: Python<'_>) -> Result<Cow<'a, str>, PyErr> ⓘ
pub fn to_cow<'a>(&'a self, py: Python<'_>) -> Result<Cow<'a, 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).
Because str
objects are immutable, the returned slice is independent of
the GIL lifetime.
pub fn to_string_lossy<'a>(&'a self, py: Python<'_>) -> Cow<'a, str>
pub fn to_string_lossy<'a>(&'a self, py: Python<'_>) -> Cow<'a, str>
Converts the PyString
into a Rust string.
Unpaired surrogates invalid UTF-8 sequences are
replaced with U+FFFD REPLACEMENT CHARACTER
.
Because str
objects are immutable, the returned slice is independent of
the GIL lifetime.
Trait Implementations§
§impl<T> AsPyPointer for Py<T>
impl<T> AsPyPointer for Py<T>
§impl<T> Display for Py<T>where
T: PyTypeInfo,
impl<T> Display for Py<T>where
T: PyTypeInfo,
§impl<T> Drop for Py<T>
Dropping a Py
instance decrements the reference count
on the object by one if the GIL is held.
impl<T> Drop for Py<T>
Dropping a Py
instance decrements the reference count
on the object by one if the GIL is held.
Otherwise and by default, this registers the underlying pointer to have its reference count decremented the next time PyO3 acquires the GIL.
However, if the pyo3_disable_reference_pool
conditional compilation flag
is enabled, it will abort the process.
§impl<T> From<Py<T>> for PyClassInitializer<T>where
T: PyClass,
impl<T> From<Py<T>> for PyClassInitializer<T>where
T: PyClass,
§fn from(value: Py<T>) -> PyClassInitializer<T>
fn from(value: Py<T>) -> PyClassInitializer<T>
§impl<T> FromPyObject<'_> for Py<T>where
T: PyTypeCheck,
impl<T> FromPyObject<'_> for Py<T>where
T: PyTypeCheck,
§impl<T0, T1, T2> IntoPy<Py<PyAny>> for (T0, T1, T2)
impl<T0, T1, T2> IntoPy<Py<PyAny>> for (T0, T1, T2)
§impl<T0, T1, T2, T3> IntoPy<Py<PyAny>> for (T0, T1, T2, T3)
impl<T0, T1, T2, T3> IntoPy<Py<PyAny>> for (T0, T1, T2, T3)
§impl<T0, T1, T2, T3, T4> IntoPy<Py<PyAny>> for (T0, T1, T2, T3, T4)
impl<T0, T1, T2, T3, T4> IntoPy<Py<PyAny>> for (T0, T1, T2, T3, T4)
§impl<T0, T1, T2, T3, T4, T5> IntoPy<Py<PyAny>> for (T0, T1, T2, T3, T4, T5)
impl<T0, T1, T2, T3, T4, T5> IntoPy<Py<PyAny>> for (T0, T1, T2, T3, T4, T5)
§impl<T0, T1, T2, T3, T4, T5, T6> IntoPy<Py<PyAny>> for (T0, T1, T2, T3, T4, T5, T6)
impl<T0, T1, T2, T3, T4, T5, T6> IntoPy<Py<PyAny>> for (T0, T1, T2, T3, T4, T5, T6)
§impl<T0, T1, T2, T3, T4, T5, T6, T7> IntoPy<Py<PyAny>> for (T0, T1, T2, T3, T4, T5, T6, T7)
impl<T0, T1, T2, T3, T4, T5, T6, T7> IntoPy<Py<PyAny>> for (T0, T1, T2, T3, T4, T5, T6, T7)
§impl<T0, T1, T2, T3, T4, T5, T6, T7, T8> IntoPy<Py<PyAny>> for (T0, T1, T2, T3, T4, T5, T6, T7, T8)
impl<T0, T1, T2, T3, T4, T5, T6, T7, T8> IntoPy<Py<PyAny>> for (T0, T1, T2, T3, T4, T5, T6, T7, T8)
§impl<T0, T1, T2, T3, T4, T5, T6, T7, T8, T9> IntoPy<Py<PyAny>> for (T0, T1, T2, T3, T4, T5, T6, T7, T8, T9)
impl<T0, T1, T2, T3, T4, T5, T6, T7, T8, T9> IntoPy<Py<PyAny>> for (T0, T1, T2, T3, T4, T5, T6, T7, T8, T9)
§impl<T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> IntoPy<Py<PyAny>> for (T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10)
impl<T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> IntoPy<Py<PyAny>> for (T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10)
§impl<T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> IntoPy<Py<PyAny>> for (T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11)
impl<T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> IntoPy<Py<PyAny>> for (T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11)
§impl IntoPy<Py<PyAny>> for PyBackedBytes
impl IntoPy<Py<PyAny>> for PyBackedBytes
§impl IntoPy<Py<PyAny>> for PyBackedStr
impl IntoPy<Py<PyAny>> for PyBackedStr
§impl IntoPy<Py<PyAny>> for SystemTime
impl IntoPy<Py<PyAny>> for SystemTime
§impl<T0, T1, T2> IntoPy<Py<PyTuple>> for (T0, T1, T2)
impl<T0, T1, T2> IntoPy<Py<PyTuple>> for (T0, T1, T2)
§impl<T0, T1, T2, T3> IntoPy<Py<PyTuple>> for (T0, T1, T2, T3)
impl<T0, T1, T2, T3> IntoPy<Py<PyTuple>> for (T0, T1, T2, T3)
§impl<T0, T1, T2, T3, T4> IntoPy<Py<PyTuple>> for (T0, T1, T2, T3, T4)
impl<T0, T1, T2, T3, T4> IntoPy<Py<PyTuple>> for (T0, T1, T2, T3, T4)
§impl<T0, T1, T2, T3, T4, T5> IntoPy<Py<PyTuple>> for (T0, T1, T2, T3, T4, T5)
impl<T0, T1, T2, T3, T4, T5> IntoPy<Py<PyTuple>> for (T0, T1, T2, T3, T4, T5)
§impl<T0, T1, T2, T3, T4, T5, T6> IntoPy<Py<PyTuple>> for (T0, T1, T2, T3, T4, T5, T6)
impl<T0, T1, T2, T3, T4, T5, T6> IntoPy<Py<PyTuple>> for (T0, T1, T2, T3, T4, T5, T6)
§impl<T0, T1, T2, T3, T4, T5, T6, T7> IntoPy<Py<PyTuple>> for (T0, T1, T2, T3, T4, T5, T6, T7)
impl<T0, T1, T2, T3, T4, T5, T6, T7> IntoPy<Py<PyTuple>> for (T0, T1, T2, T3, T4, T5, T6, T7)
§impl<T0, T1, T2, T3, T4, T5, T6, T7, T8> IntoPy<Py<PyTuple>> for (T0, T1, T2, T3, T4, T5, T6, T7, T8)
impl<T0, T1, T2, T3, T4, T5, T6, T7, T8> IntoPy<Py<PyTuple>> for (T0, T1, T2, T3, T4, T5, T6, T7, T8)
§impl<T0, T1, T2, T3, T4, T5, T6, T7, T8, T9> IntoPy<Py<PyTuple>> for (T0, T1, T2, T3, T4, T5, T6, T7, T8, T9)
impl<T0, T1, T2, T3, T4, T5, T6, T7, T8, T9> IntoPy<Py<PyTuple>> for (T0, T1, T2, T3, T4, T5, T6, T7, T8, T9)
§impl<T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> IntoPy<Py<PyTuple>> for (T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10)
impl<T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> IntoPy<Py<PyTuple>> for (T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10)
§impl<T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> IntoPy<Py<PyTuple>> for (T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11)
impl<T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> IntoPy<Py<PyTuple>> for (T0, T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11)
§impl<'a, 'py, T> IntoPyObject<'py> for &'a Py<T>
impl<'a, 'py, T> IntoPyObject<'py> for &'a Py<T>
§type Output = Borrowed<'a, 'py, <&'a Py<T> as IntoPyObject<'py>>::Target>
type Output = Borrowed<'a, 'py, <&'a Py<T> as IntoPyObject<'py>>::Target>
§type Error = Infallible
type Error = Infallible
§fn into_pyobject(
self,
py: Python<'py>,
) -> Result<<&'a Py<T> as IntoPyObject<'py>>::Output, <&'a Py<T> as IntoPyObject<'py>>::Error> ⓘ
fn into_pyobject( self, py: Python<'py>, ) -> Result<<&'a Py<T> as IntoPyObject<'py>>::Output, <&'a Py<T> as IntoPyObject<'py>>::Error> ⓘ
§impl<'py, T> IntoPyObject<'py> for Py<T>
impl<'py, T> IntoPyObject<'py> for Py<T>
§type Output = Bound<'py, <Py<T> as IntoPyObject<'py>>::Target>
type Output = Bound<'py, <Py<T> as IntoPyObject<'py>>::Target>
§type Error = Infallible
type Error = Infallible
§fn into_pyobject(
self,
py: Python<'py>,
) -> Result<<Py<T> as IntoPyObject<'py>>::Output, <Py<T> as IntoPyObject<'py>>::Error> ⓘ
fn into_pyobject( self, py: Python<'py>, ) -> Result<<Py<T> as IntoPyObject<'py>>::Output, <Py<T> as IntoPyObject<'py>>::Error> ⓘ
§impl<T> ToPyObject for Py<T>
impl<T> ToPyObject for Py<T>
impl<T> Send for Py<T>
impl<T> Sync for Py<T>
Auto Trait Implementations§
impl<T> Freeze for Py<T>
impl<T> RefUnwindSafe for Py<T>where
T: RefUnwindSafe,
impl<T> Unpin for Py<T>where
T: Unpin,
impl<T> UnwindSafe for Py<T>where
T: UnwindSafe,
Blanket Implementations§
§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
§type ArchivedMetadata = ()
type ArchivedMetadata = ()
§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> ByteSized for T
impl<T> ByteSized for T
Source§const BYTE_ALIGN: usize = _
const BYTE_ALIGN: usize = _
Source§fn byte_align(&self) -> usize ⓘ
fn byte_align(&self) -> usize ⓘ
Source§fn ptr_size_ratio(&self) -> [usize; 2]
fn ptr_size_ratio(&self) -> [usize; 2]
Source§impl<T, R> Chain<R> for Twhere
T: ?Sized,
impl<T, R> Chain<R> for Twhere
T: ?Sized,
Source§impl<T> ExtAny for T
impl<T> ExtAny for T
Source§fn as_any_mut(&mut self) -> &mut dyn Anywhere
Self: Sized,
fn as_any_mut(&mut self) -> &mut dyn Anywhere
Self: Sized,
Source§impl<T> ExtMem for Twhere
T: ?Sized,
impl<T> ExtMem for Twhere
T: ?Sized,
Source§const NEEDS_DROP: bool = _
const NEEDS_DROP: bool = _
Source§fn mem_align_of_val(&self) -> usize ⓘ
fn mem_align_of_val(&self) -> usize ⓘ
Source§fn mem_size_of_val(&self) -> usize ⓘ
fn mem_size_of_val(&self) -> usize ⓘ
Source§fn mem_needs_drop(&self) -> bool
fn mem_needs_drop(&self) -> bool
true
if dropping values of this type matters. Read moreSource§fn mem_forget(self)where
Self: Sized,
fn mem_forget(self)where
Self: Sized,
self
without running its destructor. Read moreSource§fn mem_replace(&mut self, other: Self) -> Selfwhere
Self: Sized,
fn mem_replace(&mut self, other: Self) -> Selfwhere
Self: Sized,
Source§unsafe fn mem_zeroed<T>() -> T
unsafe fn mem_zeroed<T>() -> T
unsafe_layout
only.T
represented by the all-zero byte-pattern. Read moreSource§unsafe fn mem_transmute_copy<Src, Dst>(src: &Src) -> Dst
unsafe fn mem_transmute_copy<Src, Dst>(src: &Src) -> Dst
unsafe_layout
only.T
represented by the all-zero byte-pattern. Read moreSource§fn mem_as_bytes(&self) -> &[u8] ⓘ
fn mem_as_bytes(&self) -> &[u8] ⓘ
unsafe_slice
only.§impl<'py, T> FromPyObjectBound<'_, 'py> for Twhere
T: FromPyObject<'py>,
impl<'py, T> FromPyObjectBound<'_, 'py> for Twhere
T: FromPyObject<'py>,
§impl<S> FromSample<S> for S
impl<S> FromSample<S> for S
fn from_sample_(s: S) -> S
Source§impl<T> Hook for T
impl<T> Hook for T
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
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 Twhere
T: IntoPyObject<'py>,
impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
§fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr> ⓘ
fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr> ⓘ
self
into an owned Python object, dropping type information.§impl<F, T> IntoSample<T> for Fwhere
T: FromSample<F>,
impl<F, T> IntoSample<T> for Fwhere
T: FromSample<F>,
fn into_sample(self) -> T
§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError> ⓘ
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError> ⓘ
§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
out
indicating that a T
is niched.