I've modified a wit file I'm working with from being just a string
to use a tuple<string, string>
.
After this change, when I load the wasm component into wasmtime, I get a runtime error:
failed to convert function `[method]agg.apply` to given type
I'm using wasmtime 0.15
, and wit-bindgen 0.15
.
This code was working fine when using just the string
directly.
My entire wit file looks like:
package thalo:aggregate;
world aggregate {
export aggregate: interface {
record event {
event: string,
payload: string,
}
record command {
command: string,
payload: string,
}
variant error {
command(string),
deserialize-command(tuple<string, string>), // This worked when it was just a (string)
deserialize-context(string),
deserialize-event(tuple<string, string>), // and this
serialize-error(string),
serialize-event(tuple<string, string>), // and this
}
resource agg {
constructor(id: string);
apply: func(events: list<event>) -> result<_, error>;
handle: func(command: command) -> result<list<event>, error>;
}
}
}
I think this is an error message which would result from the embedding code you're using. Can you share the rest of the Wasmtime code? Either that or can you share steps to reproduce?
Well I hope its okay if I just share the link to the Github repo. It's pretty much the same code, but I only changed some of the variants in the error enum from string
to tuple<string, string>
.
I don't know what I could be doing wrong on my side, as it works before making this change, and the code compiled fine too. Just at runtime it doesn't like it.
Here's where I load the component from file:
https://github.com/thalo-rs/thalo/blob/e64c8f28405a76a38032254ebbc0c7996b2d1e24/crates/thalo_runtime/src/module.rs#L51-L68
Here's the aggregate.wit
file:
https://github.com/thalo-rs/thalo/blob/main/crates/thalo_runtime/wit/aggregate.wit
And finally the guest side implementation:
https://github.com/thalo-rs/thalo/blob/e64c8f28405a76a38032254ebbc0c7996b2d1e24/crates/thalo/src/macros.rs#L21-L75
It looks like you have a copy of the wit inline in the guest code: https://github.com/thalo-rs/thalo/blob/e64c8f28405a76a38032254ebbc0c7996b2d1e24/crates/thalo/src/macros.rs#L22
If the two copies are out of sync you would get that sort of error.
Though i did copy the changes across so they were identical, i don't believe i did anything wrong
I have noted odd cache (?) issues with wit-bindgen-rust in the past that have prevented WIT changes from being reflected in generated code. I believe I needed some combination of cargo clean
and restarting rust-analyzer to resolve.
Oh okay I'll give it another try in that case, could possibly be the issue
Let us know if that does resolve it; if there is a latent issue with wit-bindgen-rust we should try to hunt that down.
ah it worked after a cargo clean! I'll have to keep that in mind, thank you!
Ari Seyhun has marked this topic as resolved.
https://github.com/bytecodealliance/wit-bindgen/issues/773
@Ari Seyhun would you happen to remember the sequence of steps you did to reproduce this? I'd be interested to dig in further to see if I can reproduce and fix the original issue if there is one in wit-bindgen
is the let _ = include_bytes!(...);
hack still necessary in macros to pick up changes to external files?
AFAIK yes
oh wit-bindgen does include_str
:thumbs_up:
I've just tried playing around with the wit types without doing any cargo clean to see if I could replicate it again in my repo, however I can't seem to replicate it now.
I'm doubting myself, if I had done something wrong, but I'm quite sure I didn't since it only worked when I did the cargo clean and without changing any code.
I'll keep playing around some more to see if I can make it happen again and I'll let you know
Last updated: Jan 24 2025 at 00:11 UTC