Struct mun_libloader::MunLibrary
source · pub struct MunLibrary(_);
Implementations§
source§impl MunLibrary
impl MunLibrary
sourcepub unsafe fn new(library_path: &Path) -> Result<Self, Error>
pub unsafe fn new(library_path: &Path) -> Result<Self, Error>
Loads a munlib library from disk.
Safety
A munlib is simply a shared object. When a library is loaded, initialisation routines contained within it are executed. For the purposes of safety, the execution of these routines is conceptually the same calling an unknown foreign function and may impose arbitrary requirements on the caller for the call to be sound.
Additionally, the callers of this function must also ensure that execution of the termination routines contained within the library is safe as well. These routines may be executed when the library is unloaded.
See libloading::Library::new
for more information.
pub fn into_inner(self) -> TempLibrary
sourcepub unsafe fn get_abi_version(&self) -> u32
pub unsafe fn get_abi_version(&self) -> u32
Returns the ABI version of this mun library.
Safety
This operations executes a function in the munlib. There is no guarantee that the execution of the function wont result in undefined behavior.
sourcepub unsafe fn get_info(&self) -> AssemblyInfo<'static>
pub unsafe fn get_info(&self) -> AssemblyInfo<'static>
Returns the assembly info exported by the shared object.
Safety
This operations executes a function in the munlib. There is no guarantee that the execution of the function wont result in undefined behavior.
sourcepub unsafe fn set_allocator_handle(&mut self, allocator_ptr: *mut c_void)
pub unsafe fn set_allocator_handle(&mut self, allocator_ptr: *mut c_void)
Stores the allocator handle inside the shared object. This is used by the internals of the library to be able to allocate memory.
Safety
This operations executes a function in the munlib. There is no guarantee that the execution of the function wont result in undefined behavior.