I'm trying to write wit definitions to use with wit-bindgen to turn my wasi v1 module into a wasi v2 component, and I'm stumbling on the result type.
I have a Rust function that returns this and the error defined here
wit_bindgen::generate!({
world: "femark",
exports: {
world: MyFemark,
},
});
struct MyFemark;
impl Guest for MyFemark {
fn run() {
print("Hello, world!");
}
fn process_markdown_to_html(
input: String,
) -> std::result::Result<HTMLOutput, HighlighterError> {
process_markdown_to_html(input)
}
and I tried to define it in wit like so:
// wit/femark.wit
package example:host;
world femark {
record html-output{
toc: option<string>,
content: string,
}
/// The set of errors which may be raised by the function
variant highlightererror {
model-not-supported,
runtime-error(string),
invalid-input(string)
}
export process-markdown-to-html: func(input: string) -> result<html-output, highlightererror>;
}
However no matter what combination of things I define, I get errors in validation. Some versions say that I need to make the result type in Rust match Highlightererror. If I do that it complains about conflicting Error impls and duplicate definitions. Any chance someone can point out my mistake?
Can you paste the full error message? I can get your example compiling by removing the run
function and changing HTMLOutput
to HtmlOutput
and changing HilighterError
to Highlightererror
myself
For full context, the crate I'm trying to get into wasi is here: https://github.com/benwis/femark/tree/wasi
I'm able to compile it into wasi(with some help) by installing the wasi-sdk and building it with RUSTFLAGS='-L /opt/wasi-sdk-21.0/share/wasi-sysroot/lib/wasm32-wasi' CXXSTDLIB=c++ CC=/opt/wasi-sdk-21.0/bin/clang CXX=/opt/wasi-sdk-21.0/bin/clang cargo build --target wasm32-wasi
Here is the error I get trying to add the wit-bindgen stuff
error[E0428]: the name `HtmlOutput` is defined multiple times
--> src/lib.rs:323:1
|
15 | wit_bindgen::generate!({
| ----------------------- previous definition of the type `HtmlOutput` here
...
323 | pub struct HtmlOutput {
| ^^^^^^^^^^^^^^^^^^^^^ `HtmlOutput` redefined here
|
= note: `HtmlOutput` must be defined only once in the type namespace of this module
error[E0428]: the name `HighlighterError` is defined multiple times
--> src/lib.rs:504:1
|
15 | wit_bindgen::generate!({
| ----------------------- previous definition of the type `HighlighterError` here
...
504 | enum HighlighterError {
| ^^^^^^^^^^^^^^^^^^^^^ `HighlighterError` redefined here
|
= note: `HighlighterError` must be defined only once in the type namespace of this module
error[E0119]: conflicting implementations of trait `Debug` for type `HighlighterError`
--> src/lib.rs:503:10
|
15 | / wit_bindgen::generate!({
16 | | // the name of the world in the `*.wit` input file
17 | | world: "femark",
18 | |
... |
25 | | },
26 | | });
| |__- first implementation here
...
503 | #[derive(Debug, thiserror::Error)]
| ^^^^^ conflicting implementation for `HighlighterError`
|
= note: this error originates in the derive macro `Debug` (in Nightly builds, run with -Z macro-backtrace for more info)
error[E0119]: conflicting implementations of trait `std::fmt::Display` for type `HighlighterError`
--> src/lib.rs:503:17
|
15 | / wit_bindgen::generate!({
16 | | // the name of the world in the `*.wit` input file
17 | | world: "femark",
18 | |
... |
25 | | },
26 | | });
| |__- first implementation here
...
503 | #[derive(Debug, thiserror::Error)]
| ^^^^^^^^^^^^^^^^ conflicting implementation for `HighlighterError`
|
= note: this error originates in the derive macro `thiserror::Error` (in Nightly builds, run with -Z macro-backtrace for more info)
error[E0119]: conflicting implementations of trait `StdError` for type `HighlighterError`
--> src/lib.rs:503:17
|
15 | / wit_bindgen::generate!({
16 | | // the name of the world in the `*.wit` input file
17 | | world: "femark",
18 | |
... |
25 | | },
26 | | });
| |__- first implementation here
...
503 | #[derive(Debug, thiserror::Error)]
| ^^^^^^^^^^^^^^^^ conflicting implementation for `HighlighterError`
|
= note: this error originates in the derive macro `thiserror::Error` (in Nightly builds, run with -Z macro-backtrace for more info)
Some errors have detailed explanations: E0119, E0428.
For more information about an error, try `rustc --explain E0119`.
error: could not compile `femark` (lib) due to 5 previous errors
I think what's throwing me for a loop right now is that functions are defined in Rust, but possibly the return/input types from those functions are defined in wit and then autogenerated and reused in Rust? So if I want an Error type, I have to accept whatever error type gets generated from the wit binding, and not have my own defined somewhere . Currently I thought the macro was trying to match my rust error type with the wit one, but it sounds like that is not so
I think you are right that wit-bindgen will unconditionally define its own types and you need to export them to users of your library.
For resources (opaque objects referenced on the other side) at least the host side supports the with
keyword to interact with types defined in non-autogenerated code. See this small demo for details.
Last updated: Jan 24 2025 at 00:11 UTC