Skip to main content

PyArrowBuffer

Struct PyArrowBuffer 

Source
pub struct PyArrowBuffer(/* private fields */);
Expand description

A wrapper around an Arrow Buffer.

This implements both import and export via the Python buffer protocol.

§Buffer import

This can be very useful as a general way to support ingest of a Python buffer protocol object. The underlying Arrow Buffer manages the external memory, automatically calling the Python buffer’s release callback when the Arrow Buffer reference count reaches 0.

This does not need to be used with Arrow at all! This can be used with any API where you want to handle both Python-provided and Rust-provided buffers. PyArrowBuffer implements AsRef<[u8]>.

§Buffer export

The Python buffer protocol is implemented on this buffer to enable zero-copy data transfer of the core buffer into Python. This allows for zero-copy data sharing with numpy via numpy.frombuffer.

Implementations§

Source§

impl PyArrowBuffer

Source

pub fn new(buffer: Buffer) -> Self

Construct a new PyArrowBuffer

Source

pub fn into_inner(self) -> Buffer

Consume and return the Buffer

Trait Implementations§

Source§

impl AsRef<[u8]> for PyArrowBuffer

Source§

fn as_ref(&self) -> &[u8]

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

impl AsRef<Buffer> for PyArrowBuffer

Source§

fn as_ref(&self) -> &Buffer

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

impl<'py> FromPyObject<'_, 'py> for PyArrowBuffer

Source§

type Error = PyErr

The type returned in the event of a conversion error. Read more
Source§

fn extract(obj: Borrowed<'_, 'py, PyAny>) -> Result<Self, Self::Error>

Extracts Self from the bound smart pointer obj. Read more
Source§

impl<'py> IntoPyObject<'py> for PyArrowBuffer

Source§

type Target = PyArrowBuffer

The Python output type
Source§

type Output = Bound<'py, <PyArrowBuffer as IntoPyObject<'py>>::Target>

The smart pointer type to use. Read more
Source§

type Error = PyErr

The type returned in the event of a conversion error.
Source§

fn into_pyobject( self, py: Python<'py>, ) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>

Performs the conversion.
Source§

impl PyClass for PyArrowBuffer

Source§

const NAME: &str = "Buffer"

Name of the class. Read more
Source§

type Frozen = True

Whether the pyclass is frozen. Read more
Source§

impl PyClassBaseType for PyArrowBuffer

Source§

type LayoutAsBase = <PyArrowBuffer as PyClassImpl>::Layout

Source§

type BaseNativeType = <PyArrowBuffer as PyClassImpl>::BaseNativeType

Source§

type Initializer = PyClassInitializer<PyArrowBuffer>

Source§

type PyClassMutability = <PyArrowBuffer as PyClassImpl>::PyClassMutability

Source§

type Layout<T: PyClassImpl> = <<PyArrowBuffer as PyClassBaseType>::BaseNativeType as PyClassBaseType>::Layout<T>

The type of object layout to use for ancestors or descendants of this type.
Source§

impl PyClassImpl for PyArrowBuffer

Source§

const MODULE: Option<&str>

Module which the class will be associated with. Read more
Source§

const IS_BASETYPE: bool = true

#[pyclass(subclass)]
Source§

const IS_SUBCLASS: bool = false

#[pyclass(extends=…)]
Source§

const IS_MAPPING: bool = false

#[pyclass(mapping)]
Source§

const IS_SEQUENCE: bool = false

#[pyclass(sequence)]
Source§

const IS_IMMUTABLE_TYPE: bool = false

#[pyclass(immutable_type)]
Source§

const RAW_DOC: &'static CStr = /// A wrapper around an Arrow [Buffer]. /// /// This implements both import and export via the Python buffer protocol. /// /// ### Buffer import /// /// This can be very useful as a general way to support ingest of a Python buffer protocol object. /// The underlying Arrow [Buffer] manages the external memory, automatically calling the Python /// buffer's release callback when the Arrow [Buffer] reference count reaches 0. /// /// This does not need to be used with Arrow at all! This can be used with any API where you want /// to handle both Python-provided and Rust-provided buffers. [`PyArrowBuffer`] implements /// `AsRef<[u8]>`. /// /// ### Buffer export /// /// The Python buffer protocol is implemented on this buffer to enable zero-copy data transfer of /// the core buffer into Python. This allows for zero-copy data sharing with numpy via /// `numpy.frombuffer`.

Docstring for the class provided on the struct or enum. Read more
Source§

const DOC: &'static CStr

Fully rendered class doc, including the text_signature if a constructor is defined. Read more
Source§

type Layout = <<PyArrowBuffer as PyClassImpl>::BaseNativeType as PyClassBaseType>::Layout<PyArrowBuffer>

Description of how this class is laid out in memory
Source§

type BaseType = PyAny

Base class
Source§

type ThreadChecker = NoopThreadChecker

This handles following two situations: Read more
Source§

type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::ImmutableChild

Immutable or mutable
Source§

type Dict = PyClassDummySlot

Specify this class has #[pyclass(dict)] or not.
Source§

type WeakRef = PyClassDummySlot

Specify this class has #[pyclass(weakref)] or not.
Source§

type BaseNativeType = PyAny

The closest native ancestor. This is PyAny by default, and when you declare #[pyclass(extends=PyDict)], it’s PyDict.
Source§

fn items_iter() -> PyClassItemsIter

Source§

fn lazy_type_object() -> &'static LazyTypeObject<Self>

Source§

fn dict_offset() -> Option<PyObjectOffset>

Used to provide the dictoffset slot (equivalent to tp_dictoffset)
Source§

fn weaklist_offset() -> Option<PyObjectOffset>

Used to provide the weaklistoffset slot (equivalent to tp_weaklistoffset
Source§

impl PyClassNewTextSignature for PyArrowBuffer

Source§

const TEXT_SIGNATURE: &'static str = "(buf)"

Source§

impl PyMethods<PyArrowBuffer> for PyClassImplCollector<PyArrowBuffer>

Source§

fn py_methods(self) -> &'static PyClassItems

Source§

impl PyTypeInfo for PyArrowBuffer

Source§

const NAME: &str = <Self as ::pyo3::PyClass>::NAME

👎Deprecated since 0.28.0: prefer using ::type_object(py).name() to get the correct runtime value
Class name.
Source§

const MODULE: Option<&str> = <Self as ::pyo3::impl_::pyclass::PyClassImpl>::MODULE

👎Deprecated since 0.28.0: prefer using ::type_object(py).module() to get the correct runtime value
Module name, if any.
Source§

fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject

Returns the PyTypeObject instance for this type.
Source§

fn type_object(py: Python<'_>) -> Bound<'_, PyType>

Returns the safe abstraction over the type object.
Source§

fn is_type_of(object: &Bound<'_, PyAny>) -> bool

Checks if object is an instance of this type or a subclass of this type.
Source§

fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool

Checks if object is an instance of this type.
Source§

impl DerefToPyAny for PyArrowBuffer

Source§

impl ExtractPyClassWithClone for PyArrowBuffer

Auto Trait Implementations§

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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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<'py, T> IntoPyObjectExt<'py> for T
where T: IntoPyObject<'py>,

Source§

fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>

Converts self into an owned Python object, dropping type information.
Source§

fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>

Converts self into an owned Python object, dropping type information and unbinding it from the 'py lifetime.
Source§

fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>

Converts self into a Python object. Read more
Source§

impl<T> PyErrArguments for T
where T: for<'py> IntoPyObject<'py> + Send + Sync,

Source§

fn arguments(self, py: Python<'_>) -> Py<PyAny>

Arguments for exception
Source§

impl<T> PyTypeCheck for T
where T: PyTypeInfo,

Source§

const NAME: &'static str = T::NAME

👎Deprecated since 0.27.0: Use ::classinfo_object() instead and format the type name at runtime. Note that using built-in cast features is often better than manual PyTypeCheck usage.
Name of self. This is used in error messages, for example.
Source§

fn type_check(object: &Bound<'_, PyAny>) -> bool

Checks if object is an instance of Self, which may include a subtype. Read more
Source§

fn classinfo_object(py: Python<'_>) -> Bound<'_, PyAny>

Returns the expected type as a possible argument for the isinstance and issubclass function. 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> Allocation for T
where T: RefUnwindSafe + Send + Sync,

Source§

impl<'py, T> FromPyObjectOwned<'py> for T
where T: for<'a> FromPyObject<'a, 'py>,

Source§

impl<T> Ungil for T
where T: Send,