[−][src]Struct pyo3::prelude::Py
A Python object of known type.
Accessing this object is thread-safe, since any access to its API requires a
Python<'py> GIL token.
See the guide for an explanation of the different Python object types.
Technically, it is a safe wrapper around NonNull<ffi::PyObject> with
specified type information.
Implementations
impl<T> Py<T>[src]
pub fn new(
py: Python,
value: impl Into<PyClassInitializer<T>>
) -> PyResult<Py<T>> where
T: PyClass,
T::BaseLayout: PyBorrowFlagLayout<T::BaseType>, [src]
py: Python,
value: impl Into<PyClassInitializer<T>>
) -> PyResult<Py<T>> where
T: PyClass,
T::BaseLayout: PyBorrowFlagLayout<T::BaseType>,
Create a new instance Py<T>.
This method is soft-duplicated since PyO3 0.9.0.
Use PyCell::new and
Py::from instead.
pub unsafe fn from_owned_ptr(ptr: *mut PyObject) -> Py<T>[src]
Creates a Py<T> instance for the given FFI pointer.
This moves ownership over the pointer into the Py<T>.
Undefined behavior if the pointer is NULL or invalid.
pub unsafe fn from_owned_ptr_or_panic(ptr: *mut PyObject) -> Py<T>[src]
Creates a Py<T> instance for the given FFI pointer.
Panics if the pointer is NULL. Undefined behavior if the pointer is invalid.
pub unsafe fn from_owned_ptr_or_err(
py: Python,
ptr: *mut PyObject
) -> PyResult<Py<T>>[src]
py: Python,
ptr: *mut PyObject
) -> PyResult<Py<T>>
Construct Py<T> from the result of a Python FFI call that
Returns a new reference (owned pointer).
Returns Err(PyErr) if the pointer is NULL.
Unsafe because the pointer might be invalid.
pub unsafe fn from_borrowed_ptr(ptr: *mut PyObject) -> Py<T>[src]
Creates a Py<T> instance for the given Python FFI pointer.
Calls Py_INCREF() on the ptr.
Undefined behavior if the pointer is NULL or invalid.
pub fn get_refcnt(&self) -> isize[src]
Gets the reference count of the ffi::PyObject pointer.
pub fn clone_ref(&self, _py: Python) -> Py<T>[src]
Clones self by calling Py_INCREF() on the ptr.
Trait Implementations
impl<T> AsPyPointer for Py<T>[src]
impl<T> AsPyRef for Py<T> where
T: PyTypeInfo, [src]
T: PyTypeInfo,
impl<T: Debug> Debug for Py<T>[src]
impl<T> Drop for Py<T>[src]
Dropping a Py instance decrements the reference count on the object by 1.
impl<'a, '_, T> From<&'_ PyCell<T>> for Py<T> where
T: PyClass, [src]
T: PyClass,
impl<'a, T> From<&'a T> for Py<T> where
T: AsPyPointer + PyNativeType, [src]
T: AsPyPointer + PyNativeType,
impl<T> From<Py<T>> for PyObject[src]
impl<'a, T> From<PyRef<'a, T>> for Py<T> where
T: PyClass, [src]
T: PyClass,
impl<'a, T> From<PyRefMut<'a, T>> for Py<T> where
T: PyClass, [src]
T: PyClass,
impl<'a> FromPy<&'a PyTuple> for Py<PyTuple>[src]
impl FromPy<()> for Py<PyTuple>[src]
Converts () to an empty Python tuple.
impl<'a, T> FromPyObject<'a> for Py<T> where
T: AsPyPointer,
&'a T: 'a + FromPyObject<'a>, [src]
T: AsPyPointer,
&'a T: 'a + FromPyObject<'a>,
impl<A: IntoPy<PyObject>> IntoPy<Py<PyTuple>> for (A,)[src]
impl<A: IntoPy<PyObject>, B: IntoPy<PyObject>> IntoPy<Py<PyTuple>> for (A, B)[src]
impl<A: IntoPy<PyObject>, B: IntoPy<PyObject>, C: IntoPy<PyObject>> IntoPy<Py<PyTuple>> for (A, B, C)[src]
impl<A: IntoPy<PyObject>, B: IntoPy<PyObject>, C: IntoPy<PyObject>, D: IntoPy<PyObject>> IntoPy<Py<PyTuple>> for (A, B, C, D)[src]
impl<A: IntoPy<PyObject>, B: IntoPy<PyObject>, C: IntoPy<PyObject>, D: IntoPy<PyObject>, E: IntoPy<PyObject>> IntoPy<Py<PyTuple>> for (A, B, C, D, E)[src]
impl<A: IntoPy<PyObject>, B: IntoPy<PyObject>, C: IntoPy<PyObject>, D: IntoPy<PyObject>, E: IntoPy<PyObject>, F: IntoPy<PyObject>> IntoPy<Py<PyTuple>> for (A, B, C, D, E, F)[src]
impl<A: IntoPy<PyObject>, B: IntoPy<PyObject>, C: IntoPy<PyObject>, D: IntoPy<PyObject>, E: IntoPy<PyObject>, F: IntoPy<PyObject>, G: IntoPy<PyObject>> IntoPy<Py<PyTuple>> for (A, B, C, D, E, F, G)[src]
impl<A: IntoPy<PyObject>, B: IntoPy<PyObject>, C: IntoPy<PyObject>, D: IntoPy<PyObject>, E: IntoPy<PyObject>, F: IntoPy<PyObject>, G: IntoPy<PyObject>, H: IntoPy<PyObject>> IntoPy<Py<PyTuple>> for (A, B, C, D, E, F, G, H)[src]
impl<A: IntoPy<PyObject>, B: IntoPy<PyObject>, C: IntoPy<PyObject>, D: IntoPy<PyObject>, E: IntoPy<PyObject>, F: IntoPy<PyObject>, G: IntoPy<PyObject>, H: IntoPy<PyObject>, I: IntoPy<PyObject>> IntoPy<Py<PyTuple>> for (A, B, C, D, E, F, G, H, I)[src]
impl<T> IntoPy<PyObject> for Py<T>[src]
fn into_py(self, _py: Python) -> PyObject[src]
Converts a Py instance to PyObject.
Consumes self without calling Py_DECREF().
impl<T> IntoPyPointer for Py<T>[src]
#[must_use]fn into_ptr(self) -> *mut PyObject[src]
Gets the underlying FFI pointer, returns a owned pointer.
impl<T> PartialEq<Py<T>> for Py<T>[src]
impl<T> Send for Py<T>[src]
impl<T> Sync for Py<T>[src]
impl<T> ToPyObject for Py<T>[src]
Auto Trait Implementations
impl<T> RefUnwindSafe for Py<T> where
T: RefUnwindSafe,
T: RefUnwindSafe,
impl<T> Unpin for Py<T> where
T: Unpin,
T: Unpin,
impl<T> UnwindSafe for Py<T> where
T: UnwindSafe,
T: UnwindSafe,
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized, [src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized, [src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized, [src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T[src]
impl<T> From<T> for T[src]
impl<T> FromPy<T> for T[src]
impl<'a, T> FromPyObject<'a> for T where
T: PyClass + Clone, [src]
T: PyClass + Clone,
impl<T, U> Into<U> for T where
U: From<T>, [src]
U: From<T>,
impl<T, U> IntoPy<U> for T where
U: FromPy<T>, [src]
U: FromPy<T>,
impl<T> ToBorrowedObject for T where
T: ToPyObject, [src]
T: ToPyObject,
default fn with_borrowed_ptr<F, R>(&Self, Python, F) -> R where
F: FnOnce(*mut PyObject) -> R, [src]
F: FnOnce(*mut PyObject) -> R,
impl<T> ToBorrowedObject for T where
T: ToPyObject + AsPyPointer, [src]
T: ToPyObject + AsPyPointer,
impl<T, U> TryFrom<U> for T where
U: Into<T>, [src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>, [src]
U: TryFrom<T>,