Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                
Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Added Wasmer Js API #2460

Merged
merged 112 commits into from
Jul 24, 2021
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
112 commits
Select commit Hold shift + click to select a range
430113d
Added basic example of Wasmer-js
syrusakbary Jun 22, 2021
caacec6
Updated README
syrusakbary Jun 22, 2021
ea4682f
Simplified README
syrusakbary Jun 22, 2021
45053d6
Improved READMEs
syrusakbary Jun 22, 2021
90f8f4b
Improved instrucitons on how to compile to wasm
syrusakbary Jun 22, 2021
82e2cf8
Improved instance test
syrusakbary Jun 22, 2021
f52a44d
Added support for calling functions
syrusakbary Jun 22, 2021
91b2427
Added partial support for function imports
syrusakbary Jun 23, 2021
b326903
Imported native functions now work!
syrusakbary Jun 23, 2021
6a40185
Added proof of concept of function bindings
syrusakbary Jun 23, 2021
25907c4
Enable ptr
syrusakbary Jun 23, 2021
6696877
Improved wasmer types
syrusakbary Jun 23, 2021
3d841a6
Improved function usage
syrusakbary Jun 23, 2021
0db591a
Skip wasm-opt for now
syrusakbary Jun 23, 2021
756a2a2
Added ptr api
syrusakbary Jun 24, 2021
1fae2ed
Make all tests pass
syrusakbary Jun 24, 2021
5cc350f
Simplified API
syrusakbary Jun 24, 2021
6d72966
Use wasmer_js for now in the derive
syrusakbary Jun 24, 2021
d300a1b
Merge branch 'features-cell' into js-api
syrusakbary Jun 24, 2021
5451d71
Fix syntax again
syrusakbary Jun 25, 2021
0d84e33
Updated js-api to latest
syrusakbary Jul 12, 2021
d25b2cb
Improved compilation
syrusakbary Jul 12, 2021
2c75468
Improved type reflection
syrusakbary Jul 13, 2021
ee006c3
Improved memory type
syrusakbary Jul 13, 2021
447a60b
Fix typo
syrusakbary Jul 13, 2021
38ed46b
Added reflection API
syrusakbary Jul 13, 2021
92755a0
Removed unused code
syrusakbary Jul 13, 2021
1154601
Fixed linting
syrusakbary Jul 13, 2021
9b76bae
Added Wasmer-JS workflow
syrusakbary Jul 13, 2021
87ae2ff
Improved memory & function comparison
syrusakbary Jul 13, 2021
226f985
Improved tests readability
syrusakbary Jul 13, 2021
f46b01c
Improved tests clarity
syrusakbary Jul 13, 2021
a55f157
Added partial support for tables
syrusakbary Jul 13, 2021
83d061d
Fixed lints
syrusakbary Jul 13, 2021
c6d25ff
Improved API further
syrusakbary Jul 13, 2021
a4d4b3f
Commented main file
syrusakbary Jul 13, 2021
0735a5e
Added support for Globals
syrusakbary Jul 13, 2021
e674afe
Added extra test
syrusakbary Jul 13, 2021
75b7554
Fixed memory grow
syrusakbary Jul 13, 2021
07e7ed5
Improved README
syrusakbary Jul 13, 2021
4a21652
Improved size guides
syrusakbary Jul 13, 2021
70eaf70
Added support for dynamic functions
syrusakbary Jul 14, 2021
4a3be47
Merge branch 'js-api' of github.com:wasmerio/wasmer into js-api
syrusakbary Jul 14, 2021
e7670b5
Added full support for dynamic functions
syrusakbary Jul 14, 2021
917667a
Native function now works fully
syrusakbary Jul 14, 2021
cb77e65
Fixed linting
syrusakbary Jul 14, 2021
47ffb54
Fixed lint and errors
syrusakbary Jul 14, 2021
1729ab9
Trying to fix lint issues
syrusakbary Jul 14, 2021
bd2cc94
Cleaned unused code
syrusakbary Jul 14, 2021
d5789aa
Fixed tests added extra native function test
syrusakbary Jul 14, 2021
f01c9af
Fixed lint
syrusakbary Jul 14, 2021
841509c
Fixed lint again
syrusakbary Jul 14, 2021
b9b678c
Merge branch 'master' into js-api
syrusakbary Jul 14, 2021
ecbd026
Added full support for custom RuntimeErrors. Fixed warnings
syrusakbary Jul 14, 2021
bfbd088
Added custom error test
syrusakbary Jul 14, 2021
66ff6b4
Apply suggestions from code review
syrusakbary Jul 14, 2021
8c7ba37
Uncomment code
syrusakbary Jul 14, 2021
aedadf6
Merge branch 'js-api' of github.com:wasmerio/wasmer into js-api
syrusakbary Jul 14, 2021
983190c
Fixed issues
syrusakbary Jul 14, 2021
93b8411
Improved code based on feedback
syrusakbary Jul 14, 2021
40df445
Improved traps, now fully working
syrusakbary Jul 14, 2021
27b2218
Fix wasmer-derive to optionally depend from wasmer_js
syrusakbary Jul 14, 2021
fb461c3
Fixed lint
syrusakbary Jul 14, 2021
8047e3e
Addressed feedback
syrusakbary Jul 14, 2021
ed9134a
Improved traps
syrusakbary Jul 15, 2021
a2bae12
Added extra instruction for wasmer-js
syrusakbary Jul 15, 2021
7195a9c
Fixed errors and warnings
syrusakbary Jul 15, 2021
88ff6b8
Improved wasmer-js debugging
syrusakbary Jul 15, 2021
fe04ea8
Added WebAssembly Module converter
syrusakbary Jul 16, 2021
98481f5
Move ModuleInfo to wasmer-types
syrusakbary Jul 16, 2021
be54645
Use types Module
syrusakbary Jul 16, 2021
7d63e09
Removed duplicated iterator
syrusakbary Jul 16, 2021
76ea96a
[compiler] simplified codebase (we can factor this out)
syrusakbary Jul 16, 2021
c8bd30d
Simplified polyfill
syrusakbary Jul 16, 2021
5746be8
Revert "[compiler] simplified codebase (we can factor this out)"
syrusakbary Jul 16, 2021
dcd9105
Uncommented test
syrusakbary Jul 16, 2021
e9a4da2
Fixed import
syrusakbary Jul 17, 2021
32d15be
Update README.md
syrusakbary Jul 17, 2021
3e89b7d
Fixed syntax
syrusakbary Jul 17, 2021
a589020
Update lib/js-api/README.md
syrusakbary Jul 17, 2021
2912d20
Update lib/js-api/src/cell.rs
syrusakbary Jul 17, 2021
1e67623
Last round of fixes
syrusakbary Jul 17, 2021
c6b5fe0
Fixed linting
syrusakbary Jul 19, 2021
0537b63
Merge branch 'master' into js-api
syrusakbary Jul 19, 2021
6de3272
Comment problematic tests
syrusakbary Jul 19, 2021
0edd115
Merge branch 'js-api' of github.com:wasmerio/wasmer into js-api
syrusakbary Jul 19, 2021
48d32f2
Commented failing test
syrusakbary Jul 22, 2021
4ae1b77
Apply suggestions from code review
syrusakbary Jul 22, 2021
c398cae
Fix breaking change
syrusakbary Jul 22, 2021
14bd3cb
Update lib/js-api/src/externals/function.rs
syrusakbary Jul 22, 2021
17cf814
Update lib/js-api/tests/externals.rs
syrusakbary Jul 22, 2021
290358d
Update lib/js-api/src/externals/function.rs
syrusakbary Jul 22, 2021
14c75e7
Fixed RuntimeError start when instantiating wasmer-js
syrusakbary Jul 22, 2021
3117db4
Improved comments
syrusakbary Jul 22, 2021
e429b57
Fix linting
syrusakbary Jul 23, 2021
00a23f0
Merge branch 'js-api' of github.com:wasmerio/wasmer into js-api
syrusakbary Jul 23, 2021
6b2ec72
Added support for no-std
syrusakbary Jul 23, 2021
b302848
feat(api) Merge `js-api` into `api`.
Hywan Jul 23, 2021
9bc0910
feat(api) Remove all references to `wasmer-js`.
Hywan Jul 23, 2021
0ea1993
fix(api) Fix `cargo fmt`.
Hywan Jul 23, 2021
8a5caa3
feat(api) Use the same version of `hashbrown` than what we have in deps.
Hywan Jul 23, 2021
36c4f92
fix(api) Use the `sys` feature when no default features is enabled.
Hywan Jul 23, 2021
5bfd45e
doc(api) Update documentation.
Hywan Jul 23, 2021
fcc9e74
feat(api) Set crate-type only if `js` feature is turned on.
Hywan Jul 23, 2021
bc4ffb4
doc(api) Update the `README.md`.
Hywan Jul 23, 2021
3239fe4
doc(api) Improve the crate documentation.
Hywan Jul 23, 2021
9a5a10f
doc(api) Polish.
Hywan Jul 23, 2021
d3930be
Merge pull request #2489 from wasmerio/js-api-into-api
syrusakbary Jul 23, 2021
3e04015
Fixed serde dependency
syrusakbary Jul 23, 2021
1fa19a2
Improved styling for readability
syrusakbary Jul 23, 2021
58350e3
Improved wasmer api in js
syrusakbary Jul 23, 2021
124672e
Added std to js-default
syrusakbary Jul 23, 2021
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Added support for calling functions
  • Loading branch information
syrusakbary committed Jun 22, 2021
commit f52a44dc584d1c175ea332cd3c9b187341fcf823
1 change: 1 addition & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions lib/js-api/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ cfg-if = "1.0"
wat = { version = "1.0", optional = true }
thiserror = "1.0"
more-asserts = "0.2"
wasmer-derive = { path = "../derive", version = "2.0.0" }

[dev-dependencies]
wat = "1.0"
Expand Down
11 changes: 9 additions & 2 deletions lib/js-api/src/export.rs
Original file line number Diff line number Diff line change
@@ -1,14 +1,16 @@
use js_sys::Function;
use js_sys::WebAssembly::Memory;
use wasm_bindgen::JsCast;
use wasm_bindgen::JsValue;

pub type VMMemory = Memory;
pub type VMFunction = Function;

/// The value of an export passed from one instance to another.
#[derive(Debug, Clone)]
pub enum Export {
// /// A function export value.
// Function(ExportFunction),
/// A function export value.
Function(VMFunction),

// /// A table export value.
// Table(VMTable),
Expand All @@ -22,6 +24,7 @@ impl Export {
pub fn as_jsvalue(&self) -> &JsValue {
match self {
Export::Memory(js_wasm_memory) => js_wasm_memory.as_ref(),
Export::Function(js_func) => js_func.as_ref(),
_ => unimplemented!(),
}
}
Expand All @@ -32,6 +35,10 @@ impl From<JsValue> for Export {
if val.is_instance_of::<VMMemory>() {
return Export::Memory(val.unchecked_into::<VMMemory>());
}
// Leave this last
else if val.is_instance_of::<VMFunction>() {
return Export::Function(val.unchecked_into::<VMFunction>());
}
unimplemented!();
}
}
10 changes: 5 additions & 5 deletions lib/js-api/src/exports.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
use crate::export::Export;
use crate::externals::{Extern, Memory /* Function, Global, Table */};
use crate::externals::{Extern, Function /* , Global, Table */, Memory};
syrusakbary marked this conversation as resolved.
Show resolved Hide resolved
use crate::import_object::LikeNamespace;
// use crate::native::NativeFunc;
syrusakbary marked this conversation as resolved.
Show resolved Hide resolved
// use crate::WasmTypeList;
Expand Down Expand Up @@ -134,10 +134,10 @@ impl Exports {
// self.get(name)
// }

// /// Get an export as a `Func`.
// pub fn get_function(&self, name: &str) -> Result<&Function, ExportError> {
// self.get(name)
// }
/// Get an export as a `Func`.
pub fn get_function(&self, name: &str) -> Result<&Function, ExportError> {
self.get(name)
}

// /// Get an export as a `NativeFunc`.
// pub fn get_native_function<Args, Rets>(
Expand Down
186 changes: 97 additions & 89 deletions lib/js-api/src/externals/function.rs
Original file line number Diff line number Diff line change
@@ -1,24 +1,23 @@
use crate::exports::{ExportError, Exportable};
use crate::externals::Extern;
use crate::store::Store;
use crate::types::{Val, ValFuncRef};
use crate::types::{AsJs /* ValFuncRef */, Val};
use crate::FunctionType;
use crate::NativeFunc;
// use crate::NativeFunc;
use crate::RuntimeError;
use crate::WasmerEnv;
pub use inner::{FromToNativeWasmType, HostFunction, WasmTypeList, WithEnv, WithoutEnv};

use loupe::MemoryUsage;
use crate::export::{Export, VMFunction};
use std::cmp::max;
use std::ffi::c_void;
use std::fmt;
use std::sync::Arc;
use crate::exports::{Export}; // ExportFunction, ExportFunctionMetadata
// use wasmer_vm::{
// raise_user_trap, resume_panic, wasmer_call_trampoline, ImportInitializerFuncPtr,
// VMCallerCheckedAnyfunc, VMDynamicFunctionContext, VMFuncRef, VMFunction, VMFunctionBody,
// VMFunctionEnvironment, VMFunctionKind, VMTrampoline,
// };
use std::sync::Arc; // ExportFunction, ExportFunctionMetadata
// use wasmer_vm::{
// raise_user_trap, resume_panic, wasmer_call_trampoline, ImportInitializerFuncPtr,
// VMCallerCheckedAnyfunc, VMDynamicFunctionContext, VMFuncRef, VMFunction, VMFunctionBody,
// VMFunctionEnvironment, VMFunctionKind, VMTrampoline,
// };

#[repr(C)]
pub struct VMFunctionBody(u8);
Expand All @@ -40,35 +39,37 @@ pub struct VMFunctionBody(u8);
/// with native functions. Attempting to create a native `Function` with one will
/// result in a panic.
/// [Closures as host functions tracking issue](https://github.com/wasmerio/wasmer/issues/1840)
#[derive(PartialEq, MemoryUsage)]
#[derive(PartialEq)]
pub struct Function {
pub(crate) store: Store,
pub(crate) exported: ExportFunction,
pub(crate) exported: VMFunction,
}

// impl wasmer_types::WasmValueType for Function {
// /// Write the value.
// unsafe fn write_value_to(&self, p: *mut i128) {
// let func_ref =
// Val::into_vm_funcref(&Val::FuncRef(Some(self.clone())), &self.store).unwrap();
// std::ptr::write(p as *mut VMFuncRef, func_ref);
// }
impl wasmer_types::WasmValueType for Function {
/// Write the value.
unsafe fn write_value_to(&self, p: *mut i128) {
// let func_ref =
// Val::into_vm_funcref(&Val::FuncRef(Some(self.clone())), &self.store).unwrap();
// std::ptr::write(p as *mut VMFuncRef, func_ref);
unimplemented!();
syrusakbary marked this conversation as resolved.
Show resolved Hide resolved
}

// /// Read the value.
// // TODO(reftypes): this entire function should be cleaned up, `dyn Any` should
// // ideally be removed
// unsafe fn read_value_from(store: &dyn std::any::Any, p: *const i128) -> Self {
// let func_ref = std::ptr::read(p as *const VMFuncRef);
// let store = store.downcast_ref::<Store>().expect("Store expected in `Function::read_value_from`. If you see this error message it likely means you're using a function ref in a place we don't yet support it -- sorry about the inconvenience.");
// match Val::from_vm_funcref(func_ref, store) {
// Val::FuncRef(Some(fr)) => fr,
// // these bottom two cases indicate bugs in `wasmer-types` or elsewhere.
// // They should never be triggered, so we just panic.
// Val::FuncRef(None) => panic!("Null funcref found in `Function::read_value_from`!"),
// other => panic!("Invalid value in `Function::read_value_from`: {:?}", other),
// }
// }
// }
/// Read the value.
// TODO(reftypes): this entire function should be cleaned up, `dyn Any` should
// ideally be removed
unsafe fn read_value_from(store: &dyn std::any::Any, p: *const i128) -> Self {
unimplemented!();
// let func_ref = std::ptr::read(p as *const VMFuncRef);
// let store = store.downcast_ref::<Store>().expect("Store expected in `Function::read_value_from`. If you see this error message it likely means you're using a function ref in a place we don't yet support it -- sorry about the inconvenience.");
// match Val::from_vm_funcref(func_ref, store) {
// Val::FuncRef(Some(fr)) => fr,
// // these bottom two cases indicate bugs in `wasmer-types` or elsewhere.
// // They should never be triggered, so we just panic.
// Val::FuncRef(None) => panic!("Null funcref found in `Function::read_value_from`!"),
// other => panic!("Invalid value in `Function::read_value_from`: {:?}", other),
// }
syrusakbary marked this conversation as resolved.
Show resolved Hide resolved
}
}

// fn build_export_function_metadata<Env>(
// env: Env,
Expand Down Expand Up @@ -530,33 +531,39 @@ impl Function {
/// assert_eq!(sum.call(&[Value::I32(1), Value::I32(2)]).unwrap().to_vec(), vec![Value::I32(3)]);
/// ```
pub fn call(&self, params: &[Val]) -> Result<Box<[Val]>, RuntimeError> {
let arr = js_sys::Array::new_with_length(params.len() as u32);
for (i, param) in params.iter().enumerate() {
let js_value = param.as_jsvalue();
arr.set(i as u32, js_value);
}
let result = js_sys::Reflect::apply(&self.exported, &wasm_bindgen::JsValue::NULL, &arr);
Ok(vec![Val::F64(result.unwrap().as_f64().unwrap())].into_boxed_slice())
// if let Some(trampoline) = self.exported.vm_function.call_trampoline {
// let mut results = vec![Val::null(); self.result_arity()];
// self.call_wasm(trampoline, params, &mut results)?;
// return Ok(results.into_boxed_slice());
// }

unimplemented!("The function definition isn't supported for the moment");
// unimplemented!("The function definition isn't supported for the moment");
}

pub(crate) fn from_vm_export(store: &Store, wasmer_export: ExportFunction) -> Self {
unimplemented!();
// Self {
// store: store.clone(),
// exported: wasmer_export,
// }
pub(crate) fn from_vm_export(store: &Store, wasmer_export: VMFunction) -> Self {
Self {
store: store.clone(),
exported: wasmer_export,
}
}

pub(crate) fn vm_funcref(&self) -> VMFuncRef {
unimplemented!();
// let engine = self.store.engine();
// let vmsignature = engine.register_signature(&self.exported.vm_function.signature);
// engine.register_function_metadata(VMCallerCheckedAnyfunc {
// func_ptr: self.exported.vm_function.address,
// type_index: vmsignature,
// vmctx: self.exported.vm_function.vmctx,
// })
}
// pub(crate) fn vm_funcref(&self) -> VMFuncRef {
// unimplemented!();
// // let engine = self.store.engine();
// // let vmsignature = engine.register_signature(&self.exported.vm_function.signature);
// // engine.register_function_metadata(VMCallerCheckedAnyfunc {
// // func_ptr: self.exported.vm_function.address,
// // type_index: vmsignature,
// // vmctx: self.exported.vm_function.vmctx,
// // })
// }

/// Transform this WebAssembly function into a function with the
/// native ABI. See [`NativeFunc`] to learn more.
Expand Down Expand Up @@ -633,42 +640,42 @@ impl Function {
/// // This results in an error: `RuntimeError`
/// let sum_native = sum.native::<(i32, i32), i64>().unwrap();
/// ```
pub fn native<Args, Rets>(&self) -> Result<NativeFunc<Args, Rets>, RuntimeError>
where
Args: WasmTypeList,
Rets: WasmTypeList,
{
unimplemented!();
// // type check
// {
// let expected = self.exported.vm_function.signature.params();
// let given = Args::wasm_types();

// if expected != given {
// return Err(RuntimeError::new(format!(
// "given types (`{:?}`) for the function arguments don't match the actual types (`{:?}`)",
// given,
// expected,
// )));
// }
// }

// {
// let expected = self.exported.vm_function.signature.results();
// let given = Rets::wasm_types();

// if expected != given {
// // todo: error result types don't match
// return Err(RuntimeError::new(format!(
// "given types (`{:?}`) for the function results don't match the actual types (`{:?}`)",
// given,
// expected,
// )));
// }
// }

// Ok(NativeFunc::new(self.store.clone(), self.exported.clone()))
}
// pub fn native<Args, Rets>(&self) -> Result<NativeFunc<Args, Rets>, RuntimeError>
// where
// Args: WasmTypeList,
// Rets: WasmTypeList,
// {
// unimplemented!();
// // // type check
// // {
// // let expected = self.exported.vm_function.signature.params();
// // let given = Args::wasm_types();

// // if expected != given {
// // return Err(RuntimeError::new(format!(
// // "given types (`{:?}`) for the function arguments don't match the actual types (`{:?}`)",
// // given,
// // expected,
// // )));
// // }
// // }

// // {
// // let expected = self.exported.vm_function.signature.results();
// // let given = Rets::wasm_types();

// // if expected != given {
// // // todo: error result types don't match
// // return Err(RuntimeError::new(format!(
// // "given types (`{:?}`) for the function results don't match the actual types (`{:?}`)",
// // given,
// // expected,
// // )));
// // }
// // }

// // Ok(NativeFunc::new(self.store.clone(), self.exported.clone()))
// }

#[track_caller]
fn closures_unsupported_panic() -> ! {
Expand All @@ -678,7 +685,8 @@ impl Function {

impl<'a> Exportable<'a> for Function {
fn to_export(&self) -> Export {
self.exported.clone().into()
unimplemented!();
// self.exported.clone().into()
}

fn get_self_from_extern(_extern: &'a Extern) -> Result<&'a Self, ExportError> {
Expand Down Expand Up @@ -829,12 +837,12 @@ impl fmt::Debug for Function {
/// This private inner module contains the low-level implementation
/// for `Function` and its siblings.
mod inner {
use super::VMFunctionBody;
use std::array::TryFromSliceError;
use std::convert::{Infallible, TryInto};
use std::error::Error;
use std::marker::PhantomData;
use std::panic::{self, AssertUnwindSafe};
use super::VMFunctionBody;

#[cfg(feature = "experimental-reference-types-extern-ref")]
pub use wasmer_types::{ExternRef, VMExternRef};
Expand Down
Loading