Struct libloading::safe::Symbol
source · pub struct Symbol<'lib, T: 'lib> {
inner: Symbol<T>,
pd: PhantomData<&'lib T>,
}
Expand description
Symbol from a library.
This type is a safeguard against using dynamically loaded symbols after a Library
is
unloaded. The primary method to create an instance of a Symbol
is via Library::get
.
The Deref
trait implementation allows the use of Symbol
as if it was a function or variable
itself, without taking care to “extract” the function or variable manually most of the time.
Fields§
§inner: Symbol<T>
§pd: PhantomData<&'lib T>
Implementations§
source§impl<'lib, T> Symbol<'lib, T>
impl<'lib, T> Symbol<'lib, T>
sourcepub unsafe fn into_raw(self) -> Symbol<T>
pub unsafe fn into_raw(self) -> Symbol<T>
Extract the wrapped os::platform::Symbol
.
§Safety
Using this function relinquishes all the lifetime guarantees. It is up to the developer to
ensure the resulting Symbol
is not used past the lifetime of the Library
this symbol
was loaded from.
§Examples
unsafe {
let lib = Library::new("/path/to/awesome.module").unwrap();
let symbol: Symbol<*mut u32> = lib.get(b"symbol\0").unwrap();
let symbol = symbol.into_raw();
}
sourcepub unsafe fn from_raw<L>(sym: Symbol<T>, library: &'lib L) -> Symbol<'lib, T>
pub unsafe fn from_raw<L>(sym: Symbol<T>, library: &'lib L) -> Symbol<'lib, T>
Wrap the os::platform::Symbol
into this safe wrapper.
Note that, in order to create association between the symbol and the library this symbol came from, this function requires a reference to the library.
§Safety
The library
reference must be exactly the library sym
was loaded from.
§Examples
unsafe {
let lib = Library::new("/path/to/awesome.module").unwrap();
let symbol: Symbol<*mut u32> = lib.get(b"symbol\0").unwrap();
let symbol = symbol.into_raw();
let symbol = Symbol::from_raw(symbol, &lib);
}
sourcepub unsafe fn try_as_raw_ptr(self) -> Option<*mut c_void>
pub unsafe fn try_as_raw_ptr(self) -> Option<*mut c_void>
Try to convert the symbol into a raw pointer. Success depends on the platform. Currently, this fn always succeeds and returns some.
§Safety
Using this function relinquishes all the lifetime guarantees. It is up to the developer to
ensure the resulting Symbol
is not used past the lifetime of the Library
this symbol
was loaded from.
source§impl<'lib, T> Symbol<'lib, Option<T>>
impl<'lib, T> Symbol<'lib, Option<T>>
sourcepub fn lift_option(self) -> Option<Symbol<'lib, T>>
pub fn lift_option(self) -> Option<Symbol<'lib, T>>
Lift Option out of the symbol.
§Examples
unsafe {
let lib = Library::new("/path/to/awesome.module").unwrap();
let symbol: Symbol<Option<*mut u32>> = lib.get(b"symbol\0").unwrap();
let symbol: Symbol<*mut u32> = symbol.lift_option().expect("static is not null");
}
Trait Implementations§
impl<T: Send> Send for Symbol<'_, T>
impl<T: Sync> Sync for Symbol<'_, T>
Auto Trait Implementations§
impl<'lib, T> Freeze for Symbol<'lib, T>
impl<'lib, T> RefUnwindSafe for Symbol<'lib, T>where
T: RefUnwindSafe,
impl<'lib, T> Unpin for Symbol<'lib, T>where
T: Unpin,
impl<'lib, T> UnwindSafe for Symbol<'lib, T>where
T: UnwindSafe + RefUnwindSafe,
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)