2019-01-11 03:59:57 +00:00
|
|
|
use crate::{
|
2019-01-13 21:44:14 +00:00
|
|
|
instance::InstanceInner,
|
2019-01-12 22:52:14 +00:00
|
|
|
module::ExportIndex,
|
2019-01-13 21:44:14 +00:00
|
|
|
module::ModuleInner,
|
2019-01-12 22:53:17 +00:00
|
|
|
types::{FuncSig, GlobalDesc, Memory, Table},
|
2019-01-13 21:44:14 +00:00
|
|
|
vm,
|
2019-01-11 03:59:57 +00:00
|
|
|
};
|
2019-01-12 22:52:14 +00:00
|
|
|
use hashbrown::hash_map;
|
2019-01-11 03:59:57 +00:00
|
|
|
|
2019-01-12 21:24:17 +00:00
|
|
|
#[derive(Debug, Copy, Clone)]
|
2019-01-11 03:59:57 +00:00
|
|
|
pub enum Context {
|
|
|
|
External(*mut vm::Ctx),
|
|
|
|
Internal,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Debug, Clone)]
|
|
|
|
pub enum Export {
|
|
|
|
Function {
|
2019-01-12 22:52:14 +00:00
|
|
|
func: FuncPointer,
|
2019-01-11 03:59:57 +00:00
|
|
|
ctx: Context,
|
|
|
|
signature: FuncSig,
|
|
|
|
},
|
|
|
|
Memory {
|
2019-01-12 22:52:14 +00:00
|
|
|
local: MemoryPointer,
|
2019-01-11 03:59:57 +00:00
|
|
|
ctx: Context,
|
|
|
|
memory: Memory,
|
|
|
|
},
|
|
|
|
Table {
|
2019-01-12 22:52:14 +00:00
|
|
|
local: TablePointer,
|
2019-01-11 03:59:57 +00:00
|
|
|
ctx: Context,
|
|
|
|
table: Table,
|
|
|
|
},
|
|
|
|
Global {
|
2019-01-12 22:52:14 +00:00
|
|
|
local: GlobalPointer,
|
2019-01-11 03:59:57 +00:00
|
|
|
global: GlobalDesc,
|
|
|
|
},
|
|
|
|
}
|
2019-01-12 22:52:14 +00:00
|
|
|
|
|
|
|
#[derive(Debug, Clone)]
|
|
|
|
pub struct FuncPointer(*const vm::Func);
|
|
|
|
|
|
|
|
impl FuncPointer {
|
|
|
|
/// This needs to be unsafe because there is
|
|
|
|
/// no way to check whether the passed function
|
|
|
|
/// is valid and has the right signature.
|
|
|
|
pub unsafe fn new(f: *const vm::Func) -> Self {
|
|
|
|
FuncPointer(f)
|
|
|
|
}
|
|
|
|
|
|
|
|
pub(crate) fn inner(&self) -> *const vm::Func {
|
|
|
|
self.0
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Debug, Clone)]
|
|
|
|
pub struct MemoryPointer(*mut vm::LocalMemory);
|
|
|
|
|
|
|
|
impl MemoryPointer {
|
|
|
|
/// This needs to be unsafe because there is
|
|
|
|
/// no way to check whether the passed function
|
|
|
|
/// is valid and has the right signature.
|
|
|
|
pub unsafe fn new(f: *mut vm::LocalMemory) -> Self {
|
|
|
|
MemoryPointer(f)
|
|
|
|
}
|
|
|
|
|
|
|
|
pub(crate) fn inner(&self) -> *mut vm::LocalMemory {
|
|
|
|
self.0
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Debug, Clone)]
|
|
|
|
pub struct TablePointer(*mut vm::LocalTable);
|
|
|
|
|
|
|
|
impl TablePointer {
|
|
|
|
/// This needs to be unsafe because there is
|
|
|
|
/// no way to check whether the passed function
|
|
|
|
/// is valid and has the right signature.
|
|
|
|
pub unsafe fn new(f: *mut vm::LocalTable) -> Self {
|
|
|
|
TablePointer(f)
|
|
|
|
}
|
|
|
|
|
|
|
|
pub(crate) fn inner(&self) -> *mut vm::LocalTable {
|
|
|
|
self.0
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Debug, Clone)]
|
|
|
|
pub struct GlobalPointer(*mut vm::LocalGlobal);
|
|
|
|
|
|
|
|
impl GlobalPointer {
|
|
|
|
/// This needs to be unsafe because there is
|
|
|
|
/// no way to check whether the passed function
|
|
|
|
/// is valid and has the right signature.
|
|
|
|
pub unsafe fn new(f: *mut vm::LocalGlobal) -> Self {
|
|
|
|
GlobalPointer(f)
|
|
|
|
}
|
|
|
|
|
|
|
|
pub(crate) fn inner(&self) -> *mut vm::LocalGlobal {
|
|
|
|
self.0
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub struct ExportIter<'a> {
|
2019-01-13 21:44:14 +00:00
|
|
|
inner: &'a mut InstanceInner,
|
2019-01-12 22:52:14 +00:00
|
|
|
iter: hash_map::Iter<'a, String, ExportIndex>,
|
2019-01-13 21:44:14 +00:00
|
|
|
module: &'a ModuleInner,
|
2019-01-12 22:52:14 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
impl<'a> ExportIter<'a> {
|
2019-01-13 21:44:14 +00:00
|
|
|
pub(crate) fn new(module: &'a ModuleInner, inner: &'a mut InstanceInner) -> Self {
|
2019-01-12 22:52:14 +00:00
|
|
|
Self {
|
2019-01-13 21:44:14 +00:00
|
|
|
inner,
|
|
|
|
iter: module.exports.iter(),
|
|
|
|
module: module,
|
2019-01-12 22:52:14 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<'a> Iterator for ExportIter<'a> {
|
|
|
|
type Item = (String, Export);
|
|
|
|
fn next(&mut self) -> Option<(String, Export)> {
|
|
|
|
let (name, export_index) = self.iter.next()?;
|
|
|
|
Some((
|
|
|
|
name.clone(),
|
2019-01-13 21:44:14 +00:00
|
|
|
self.inner.get_export_from_index(&self.module, export_index),
|
2019-01-12 22:52:14 +00:00
|
|
|
))
|
|
|
|
}
|
2019-01-12 22:53:17 +00:00
|
|
|
}
|