Struct z_stream

Source
#[repr(C)]
pub struct z_stream {
Show 14 fields pub next_in: *const u8, pub avail_in: u32, pub total_in: u64, pub next_out: *mut u8, pub avail_out: u32, pub total_out: u64, pub msg: *mut i8, pub state: *mut internal_state, pub zalloc: Option<unsafe extern "C" fn(_: *mut c_void, _: u32, _: u32) -> *mut c_void>, pub zfree: Option<unsafe extern "C" fn(_: *mut c_void, _: *mut c_void)>, pub opaque: *mut c_void, pub data_type: i32, pub adler: u64, pub reserved: u64,
}
Expand description

The current stream state

§Custom allocators

The low-level API supports passing in a custom allocator as part of the z_stream:

struct z_stream {
    // ...
    zalloc: Option<unsafe extern "C" fn(*mut c_void, c_uint, c_uint) -> *mut c_void>,
    zfree: Option<unsafe extern "C" fn(*mut c_void, *mut c_void)>,
    opaque: *mut c_void,
}

When these fields are None (or NULL in C), the initialization functions use a default allocator, based on feature flags:

  • "rust-allocator" uses the rust global allocator
  • "c-allocator" uses an allocator based on malloc and free

When both are configured, the "rust-allocator" is preferred. When no default allocator is configured, and custom zalloc and zfree are provided, the initialization functions will return a Z_STREAM_ERROR.

When custom zalloc and zfree functions are given, they must adhere to the following contract to be safe:

  • a call zalloc(opaque, n, m) must return a pointer p to n * m bytes of memory, or NULL if out of memory
  • a call zfree(opaque, p) must free that memory

The strm.opaque value is passed to as the first argument to all calls to zalloc and zfree, but is otherwise ignored by the library.

Fields§

§next_in: *const u8§avail_in: u32§total_in: u64§next_out: *mut u8§avail_out: u32§total_out: u64§msg: *mut i8§state: *mut internal_state§zalloc: Option<unsafe extern "C" fn(_: *mut c_void, _: u32, _: u32) -> *mut c_void>§zfree: Option<unsafe extern "C" fn(_: *mut c_void, _: *mut c_void)>§opaque: *mut c_void§data_type: i32§adler: u64§reserved: u64

Implementations§

Trait Implementations§

Source§

impl Clone for z_stream

Source§

fn clone(&self) -> z_stream

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 Default for z_stream

Source§

fn default() -> z_stream

Returns the “default value” for a type. Read more
Source§

impl Copy for z_stream

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