Crates.io | wasmer-bus-macros |
lib.rs | wasmer-bus-macros |
version | 1.1.0 |
source | src |
created_at | 2022-08-08 01:34:07.137181 |
updated_at | 2022-08-08 01:34:07.137181 |
description | WebAssembly Bus Macros |
homepage | |
repository | https://github.com/john-sharratt/ate |
max_upload_size | |
id | 640496 |
size | 55,735 |
Helpful macros that make it easier to export and import APIs.
Below is a simple example of how to emit the helper classes and serialization objects for a specific API
use wasmer_bus::macros::*;
#[wasmer_bus(format = "json")]
pub trait Time {
async fn sleep(&self, duration_ms: u128);
}
It is also possible to emit a series of sub-apis that carry with them some specific context
use serde::*;
use std::sync::Arc;
use wasmer_bus::macros::*;
#[wasmer_bus(format = "bincode")]
pub trait SocketBuilder {
async fn connect(
&self,
url: String,
state_change: impl Fn(SocketState),
receive: impl Fn(Vec<u8>),
) -> Arc<dyn WebSocket>;
}
#[wasmer_bus(format = "bincode")]
pub trait WebSocket {
async fn send(&self, data: Vec<u8>) -> SendResult;
}
You can test your WASI program by uploading it to wapm.io and then heading over to the Wasmer Shell