I'm trying to provide an implementation of a world for wasmtime.
Is it possible to build a library that implements a world, and have the consumers of the library be able to combine it with other worlds to build one larger world, without having to rewrite a lot of code?
E.g. one library provides wasi-webgpu, and another one provides wasi-cli, and the consumer want's to use both.
At a first glance that doesn't seem possible, unless we force the consumers of the library to specify all the same configurations in wasmtime::component::bindgen!
as all the libraries it's using, which is really cumbersome.
Is there an easier way to do this?
This should be possible to do, but it requires some manual configuration as well as some fiddling with paths. For example with wasi:http
it's generated in the wasmtime-wasi-http
crate but it refers to other wasi types in the wasmtime-wasi
crate and is conditionally added to the CLI.
I think adding things to a linker is probably one of the more manual parts, there's not a great way to orchestrate that happening at WIT bindgen time when there's lots of libraries in play (but we could improve that too)
Thanks!
So I guess for now, the consumer will have to do a lot of manual configuration.
Actually, I can probably provide a macro that outputs the mappings for with
, since that seems like the largest part.
baby steps
do NOT help your users too much, lest they immediately ask for LOTS MORE HELP
:-)
:lol:
Mendy Berger said:
Actually, I can probably provide a macro that outputs the mappings for
with
, since that seems like the largest part.
Actually that's not possible, wasmtime::component::bindgen!
won't take a macro call.
Yeah it does require a chunk of configuration, and we haven't had a great idea about how to reduce the amount required yet
What if I structure all the webgpu resources with the exact same paths and names as the wit expects. Can I then at least map it with a single item in with
?
That would be a lot better than having to map each resource separately.
Last night you inspired me to work on https://github.com/bytecodealliance/wasmtime/pull/8083, and would that do what you're thinking?
that'd help users of webgpu but it wouldn't help you defining webgpu itself
Oh wow! That's so cool to hear!
Now, how do I inspire you to do my dishes? :lol:
If I understand correctly what it's doing, then yes, it will be a major help!
I'm okay having to specify a bit more on the library's side, if I can cut down the code on the consumer's side.
Ok cool, that's been on my todo list for awhile so I'm glad you were able to give me the push to finally implement it :)
sorry on the dishes, I've got enough of those over here heh
Do I lose all the code generation if I specify a whole interface in with
? Seems like I now have to implement my own add_to_linker
currently, yeah, but I was thinking that was something we should add back in
at the very least put a pub use
but ideally also synthesize it in add_to_linker
Just an update: I ended up splitting the libraries up at the interface level, and managed to get them to play nicely together.
Here you can see the libraries side.
And here you can see the consumer combining multiple libraries.
Ended up working really well.
Thanks for the help!!
This was all on the side of the runtime, now I'm having a similar issue on the guest side with wit-bindgen. I've created a separate thread for that.
Last updated: Jan 24 2025 at 00:11 UTC