#[repr(C, align(4096))]
pub struct CKBDLContext<T>(/* private fields */);
Available on crate feature ckb-types only.
Expand description

Dynamic loading context T represent a buffer type, for example: [u8; 64 * 1024], the size of T must aligned with PAGE_SIZE 4096.

Implementations§

source§

impl<T> CKBDLContext<T>

source

pub unsafe fn new() -> Self

👎Deprecated since 0.7.3: Please use the dynamic_loading_c_impl instead
§Unsafe

Undefined behavior will happen if the type T is not a [u8; length]

Create instance of dynamic loading context

source

pub fn load<'a>( &'a mut self, dep_cell_data_hash: &[u8] ) -> Result<Library, Error>

👎Deprecated since 0.7.3: Please use the dynamic_loading_c_impl instead

Load a shared library from dep cells See module level documentation for details

source

pub fn load_with_offset<'a>( &'a mut self, dep_cell_data_hash: &[u8], offset: usize, size: usize ) -> Result<Library, Error>

👎Deprecated since 0.7.3: Please use the dynamic_loading_c_impl instead

Load a shared library from dep cells to specified buffer offset. See module level documentation for details

This function is used for loading multiple libraries.

§Example
let mut context = CKBDLContext::<[u8; 64 * 1024]>::new();
let mut size = size_of_val(&context);
let mut offset = 0;

let lib1 = context.load(&CODE_HASH_LIB_1).expect("load shared lib");
size -= lib1.consumed_size()
offset += lib1.consumed_size()

let lib2 = context.load_with_offset(&CODE_HASH_LIB_2, offset, size).expect("load shared lib");
size -= lib2.consumed_size()
offset += lib2.consumed_size()

let lib3 = context.load_with_offset(&CODE_HASH_LIB_3, offset, size).expect("load shared lib");

Auto Trait Implementations§

§

impl<T> Freeze for CKBDLContext<T>
where T: Freeze,

§

impl<T> RefUnwindSafe for CKBDLContext<T>
where T: RefUnwindSafe,

§

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

§

impl<T> Sync for CKBDLContext<T>
where T: Sync,

§

impl<T> Unpin for CKBDLContext<T>
where T: Unpin,

§

impl<T> UnwindSafe for CKBDLContext<T>
where T: UnwindSafe,

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

§

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

§

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.