Enum wasmer_vm::ImportFunctionEnv [−][src]
pub enum ImportFunctionEnv {
NoEnv,
Env {
env: *mut c_void,
clone: fn(_: *mut c_void) -> *mut c_void,
initializer: Option<ImportInitializerFuncPtr>,
destructor: unsafe fn(_: *mut c_void),
},
}Expand description
A collection of data about host envs used by imported functions.
Variants
The vmctx pointer does not refer to a host env, there is no
metadata about it.
We’re dealing with a user-defined host env.
This host env may be either unwrapped (the user-supplied host env
directly) or wrapped. i.e. in the case of Dynamic functions, we
store our own extra data along with the user supplied env,
thus the env pointer here points to the outermost type.
Show fields
Fields of Env
env: *mut c_voidThe function environment. This is not always the user-supplied env.
clone: fn(_: *mut c_void) -> *mut c_voidA clone function for duplicating the env.
initializer: Option<ImportInitializerFuncPtr>This field is not always present. When it is present, it
should be set to None after use to prevent double
initialization.
destructor: unsafe fn(_: *mut c_void)The destructor to clean up the type in env.
Safety
- This function must be called ina synchronized way. For
example, in the
Dropimplementation of this type.
Trait Implementations
Auto Trait Implementations
impl RefUnwindSafe for ImportFunctionEnvimpl !Send for ImportFunctionEnvimpl !Sync for ImportFunctionEnvimpl Unpin for ImportFunctionEnvimpl UnwindSafe for ImportFunctionEnvBlanket Implementations
type ArchivedMetadata = ()
type ArchivedMetadata = ()The archived version of the pointer metadata for this type.
pub fn pointer_metadata(
&<T as ArchivePointee>::ArchivedMetadata
) -> <T as Pointee>::Metadata
pub fn pointer_metadata(
&<T as ArchivePointee>::ArchivedMetadata
) -> <T as Pointee>::MetadataConverts some archived metadata to the pointer metadata for itself.
Mutably borrows from an owned value. Read more