This example demonstrates how to make use of wasmedge-bindgen
and wasmedge-bindgen-macro
crates to define wasm functions that have arguments of Rust built-in types, including numeric types (such as u8, i32, f32), bool
, String
, Vec<T>
( T
is one of i8
, u8
, i16
, u16
, i32
, u32
, i64
and u64
).
This example consists of two projects:
-
wasm-lib
is a wasm library, in which wasm functions are defined. -
call-wasm-lib
is a host application that loads the wasm binary generated fromwasm-lib
, and runs the wasm function exported by the wasm library over WasmEdge Runtime.
Now let's build and run this example.
-
Install
rustup
andRust
Go to the official Rust webpage and follow the instructions to install
rustup
andRust
.It is recommended to use Rust 1.71 or above in the stable channel.
Then, add
wasm32-wasi
target to the Rustup toolchain:rustup target add wasm32-wasi
-
Install WasmEdge Runtime
Refer to the Quick Install section of WasmEdge Runtime Book to install WasmEdge Runtime. Or, use the following command directly
# NOTICE that the installation script needs `sudo` access # install wasmedge to the directory /usr/local/ curl -sSf https://raw.githubusercontent.com/WasmEdge/WasmEdge/master/utils/install.sh | bash -s -- -v 0.13.5 -p /usr/local
For users in China mainland (中国大陆地区), try the following command to install WasmEdge Runtime if failed to run the command above
# NOTICE that the installation script needs `sudo` access bash install_zh.sh -v 0.13.5 -p /usr/local
-
Download example
git clone git@github.com:second-state/wasmedge-rustsdk-examples.git cd wasmedge-rustsdk-examples/wasmedge-bindgen
-
Build
wasm-lib
cargo build -p wasm-lib --target wasm32-wasi --release
If the command runs successfully,
wasm-lib.wasm
can be found in the directory of./target/wasm32-wasi/release/
. -
Build and run
call-wasm-lib
cargo run -p call-wasm-lib -- ./target/wasm32-wasi/release/wasm_lib.wasm 5
If the command runs successfully, then the following message is printed out on the screen:
Run bindgen -- say: hello bindgen funcs test 5 Run bindgen -- say FAILED abc Run bindgen -- create_line: {"points":[{"x":2.5,"y":7.8},{"x":2.5,"y":5.8}],"valid":true,"length":2.0,"desc":"A thin red line"} Run bindgen -- obfusticate: N dhvpx oebja sbk whzcf bire gur ynml qbt Run bindgen -- sha3_digest: [87, 27, 231, 209, 189, 105, 251, 49, 159, 10, 211, 250, 15, 159, 154, 181, 43, 218, 26, 141, 56, 199, 25, 45, 60, 10, 20, 163, 54, 211, 195, 203] Run bindgen -- keccak_digest: [126, 194, 241, 200, 151, 116, 227, 33, 216, 99, 159, 22, 107, 3, 177, 169, 216, 191, 114, 156, 174, 193, 32, 159, 246, 228, 245, 133, 52, 75, 55, 27]