Struct Pool

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

Non-owning wrapper 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.

Trait Implementations§

Source§

impl Allocator for Pool

Source§

fn allocate(&self, layout: Layout) -> Result<NonNull<[u8]>, AllocError>

Attempts to allocate a block of memory. Read more
Source§

unsafe fn deallocate(&self, ptr: NonNull<u8>, layout: Layout)

Deallocates the memory referenced by ptr. Read more
§

fn allocate_zeroed(&self, layout: Layout) -> Result<NonNull<[u8]>, AllocError>

Behaves like allocate, but also ensures that the returned memory is zero-initialized. Read more
§

unsafe fn grow( &self, ptr: NonNull<u8>, old_layout: Layout, new_layout: Layout, ) -> Result<NonNull<[u8]>, AllocError>

Attempts to extend the memory block. Read more
§

unsafe fn grow_zeroed( &self, ptr: NonNull<u8>, old_layout: Layout, new_layout: Layout, ) -> Result<NonNull<[u8]>, AllocError>

Behaves like grow, but also ensures that the new contents are set to zero before being returned. Read more
§

unsafe fn shrink( &self, ptr: NonNull<u8>, old_layout: Layout, new_layout: Layout, ) -> Result<NonNull<[u8]>, AllocError>

Attempts to shrink the memory block. Read more
§

fn by_ref(&self) -> &Self
where Self: Sized,

Creates a “by reference” adapter for this instance of Allocator. Read more
Source§

impl AsMut<ngx_pool_s> for Pool

Source§

fn as_mut(&mut self) -> &mut ngx_pool_t

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

impl AsRef<ngx_pool_s> for Pool

Source§

fn as_ref(&self) -> &ngx_pool_t

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

impl Clone for Pool

Source§

fn clone(&self) -> Pool

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for Pool

Source§

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

Formats the value using the given formatter. Read more

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. 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.