Remove the need for HostRef<Module>

This commit continues previous work and also #708 by removing the need
to use `HostRef<Module>` in the API of the `wasmtime` crate. The API
changes performed here are:

* The `Module` type is now itself internally reference counted.
* The `Module::store` function now returns the `Store` that was used to
  create a `Module`
* Documentation for `Module` and its methods have been expanded.
This commit is contained in:
Alex Crichton
2020-01-08 08:30:57 -08:00
parent eb1991c579
commit 1fe76ef9e3
20 changed files with 194 additions and 110 deletions

View File

@@ -234,15 +234,14 @@ impl RunCommand {
store: &Store,
module_registry: &HashMap<String, HostRef<Instance>>,
path: &Path,
) -> Result<(HostRef<Instance>, HostRef<Module>, Vec<u8>)> {
) -> Result<(HostRef<Instance>, Module, Vec<u8>)> {
// Read the wasm module binary either as `*.wat` or a raw binary
let data = wat::parse_file(path)?;
let module = HostRef::new(Module::new(store, &data)?);
let module = Module::new(store, &data)?;
// Resolve import using module_registry.
let imports = module
.borrow()
.imports()
.iter()
.map(|i| {
@@ -285,7 +284,6 @@ impl RunCommand {
let data = ModuleData::new(&data)?;
self.invoke_export(instance, &data, name)?;
} else if module
.borrow()
.exports()
.iter()
.any(|export| export.name().is_empty())