Struct Pool

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

Wrapper struct for an ngx_pool_t pointer, providing methods for working with memory pools.

See https://nginx.org/en/docs/dev/development_guide.html#pool

Implementations§

Source§

impl Pool

Source

pub unsafe fn from_ngx_pool(pool: *mut ngx_pool_t) -> Pool

Creates a new Pool from an ngx_pool_t pointer.

§Safety

The caller must ensure that a valid ngx_pool_t pointer is provided, pointing to valid memory and non-null. A null argument will cause an assertion failure and panic.

Source

pub fn create_buffer(&mut self, size: usize) -> Option<TemporaryBuffer>

Creates a buffer of the specified size in the memory pool.

Returns Some(TemporaryBuffer) if the buffer is successfully created, or None if allocation fails.

Source

pub fn create_buffer_from_str(&mut self, str: &str) -> Option<TemporaryBuffer>

Creates a buffer from a string in the memory pool.

Returns Some(TemporaryBuffer) if the buffer is successfully created, or None if allocation fails.

Source

pub fn create_buffer_from_static_str( &mut self, str: &'static str, ) -> Option<MemoryBuffer>

Creates a buffer from a static string in the memory pool.

Returns Some(MemoryBuffer) if the buffer is successfully created, or None if allocation fails.

Source

pub fn alloc(&mut self, size: usize) -> *mut c_void

Allocates memory from the pool of the specified size. The resulting pointer is aligned to a platform word size.

Returns a raw pointer to the allocated memory.

Source

pub fn alloc_type<T: Copy>(&mut self) -> *mut T

Allocates memory for a type from the pool. The resulting pointer is aligned to a platform word size.

Returns a typed pointer to the allocated memory.

Source

pub fn calloc(&mut self, size: usize) -> *mut c_void

Allocates zeroed memory from the pool of the specified size. The resulting pointer is aligned to a platform word size.

Returns a raw pointer to the allocated memory.

Source

pub fn calloc_type<T: Copy>(&mut self) -> *mut T

Allocates zeroed memory for a type from the pool. The resulting pointer is aligned to a platform word size.

Returns a typed pointer to the allocated memory.

Source

pub fn alloc_unaligned(&mut self, size: usize) -> *mut c_void

Allocates unaligned memory from the pool of the specified size.

Returns a raw pointer to the allocated memory.

Source

pub fn alloc_type_unaligned<T: Copy>(&mut self) -> *mut T

Allocates unaligned memory for a type from the pool.

Returns a typed pointer to the allocated memory.

Source

pub fn allocate<T>(&mut self, value: T) -> *mut T

Allocates memory for a value of a specified type and adds a cleanup handler to the memory pool.

Returns a typed pointer to the allocated memory if successful, or a null pointer if allocation or cleanup handler addition fails.

Auto Trait Implementations§

§

impl Freeze for Pool

§

impl RefUnwindSafe for Pool

§

impl !Send for Pool

§

impl !Sync for Pool

§

impl Unpin for Pool

§

impl UnwindSafe for Pool

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<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.