Hi all! Rookie question here. I'm trying to modify cargo component new
's default world.wit
file so there's a function that takes a wasi:filesystem
InputStream
. However, I'm not having any luck with the first step--importing wasi:filesystem
(or any other wasi
component).
package ion:xl;
/// An example world for the component to target.
world example {
import wasi:filesystem/filesystem;
export hello-world: func() -> string;
}
Running cargo component build --release
for the above produces:
error: failed to create a target world for package `ionxl` (/Users/zslayton/experiment_wasm/jcotest/ionxl/Cargo.toml)
Caused by:
0: failed to merge local target `/Users/zslayton/experiment_wasm/jcotest/ionxl/wit`
1: package not found
--> /Users/zslayton/experiment_wasm/jcotest/ionxl/wit/world.wit:5:12
|
5 | import wasi:filesystem/filesystem;
| ^--------------
I took this to mean that I needed to supply my own copy of the WASI .wit
files, so I downloaded them from GitHub and placed them in wit/deps
alongside wit/world.wit
:
wit
wit/world.wit
wit/deps
wit/deps/sockets
wit/deps/sockets/instance-network.wit
wit/deps/sockets/world.wit
wit/deps/sockets/ip-name-lookup.wit
wit/deps/sockets/tcp-create-socket.wit
wit/deps/sockets/udp.wit
wit/deps/sockets/tcp.wit
wit/deps/sockets/udp-create-socket.wit
wit/deps/sockets/network.wit
wit/deps/clocks
wit/deps/clocks/world.wit
wit/deps/clocks/wall-clock.wit
wit/deps/clocks/monotonic-clock.wit
wit/deps/io
wit/deps/io/world.wit
wit/deps/io/streams.wit
wit/deps/io/error.wit
wit/deps/io/poll.wit
wit/deps/filesystem
wit/deps/filesystem/world.wit
wit/deps/filesystem/preopens.wit
wit/deps/filesystem/types.wit
wit/deps/cli
wit/deps/cli/imports.wit
wit/deps/cli/terminal.wit
wit/deps/cli/stdio.wit
wit/deps/cli/command.wit
wit/deps/cli/exit.wit
wit/deps/cli/run.wit
wit/deps/cli/environment.wit
wit/deps/README.md
wit/deps/http
wit/deps/http/handler.wit
wit/deps/http/proxy.wit
wit/deps/http/types.wit
wit/deps/random
wit/deps/random/world.wit
wit/deps/random/insecure.wit
wit/deps/random/insecure-seed.wit
wit/deps/random/random.wit
This didn't improve things, though. Is there something else I need to do to tell cargo component
where to find the wasi:*
WITs?
Answering my own question: despite several examples I found, it turns out you can't just import something without explicitly stating the version of the import. This works:
world example {
use wasi:io/streams@0.2.0.{input-stream, output-stream, stream-error};
export hello-world: func() -> string;
export count-bytes: func(input: input-stream) -> result<u64, stream-error>;
}
Notice the @0.2.0
in the use
statement.
I assume this is a point-in-time limitation, but it took a lot of trial and error to identify a working solution so I wanted to share it.
If you ran into any docs that almost helped, but didn't, I'd be happy to try updating them or if you want to update them that'd be great :)
Also Zulip has a "mark as resolved feature" if you're feeling this is fully resolved!
Victor Adossi said:
If you ran into any docs that almost helped, but didn't, I'd be happy to try updating them or if you want to update them that'd be great :)
Also Zulip has a "mark as resolved feature" if you're feeling this is fully resolved!
Thanks, Victor! (And apologies for the delayed reply, I've been traveling.)
I seem to have fallen into the natural documentation gap formed by the ecosystem migrating from wasi 0.1 to 0.2 on a variety of timelines. Some things that might've made my journey shorter:
arewewasiyet.rs
-type page... that summarizes where the ecosystem is in its development. As a newcomer, I visited several sites trying to get up to speed:
* https://wasi.dev
* https://component-model.bytecodealliance.org/
* https://webassembly.org/getting-started/developers-guide/
* https://github.com/bytecodealliance/cargo-component
* https://github.com/bytecodealliance/wac
It took me a while to realize that many things were still referring to wasi 0.1 concepts like Module
s which (I think?) are no longer relevant in wasi 0.2+.
It would have been great to encounter an overview page that told me up front that:
cargo component
/wac
or the wasmtime
crate) JS (via jco
). Support for other languages is nascent, and their documentation is all targeting wasi 0.1. Support for implementing a guest component is somewhat more widespread (I think tinygo
may support targeting wasi 0.2 as a guest?), but is still far behind wasi 0.1.wasi:cli
or similar you'll need to download all of the 0.2 interface files and include them in your project's source. (Maybe there's a better way but that's where I landed via trial-and-error.)wasi:*
typesMore narrowly, I wanted to build a component that took in an input-stream
and handed out a resource
that processed that input-stream
incrementally over the course of many method calls.
The highly-ranked WASI tutorial targets wasi 0.1, and so doesn't demonstrate dependencies.
In the process of writing this up, I noticed the Rust component example does demonstrate an import
statement using a version number, but it was subtle enough that I didn't notice it before.
The error messages I was encountering when I left the version number off (reproduced below for ease-of-reference) didn't mention a version number. They also point to the beginning of the name of the package being imported, so I thought it couldn't find the package itself:
error: failed to create a target world for package ionxl
(/Users/zslayton/experiment_wasm/jcotest/ionxl/Cargo.toml)
Caused by:
0: failed to merge local target `/Users/zslayton/experiment_wasm/jcotest/ionxl/wit`
1: package not found
--> /Users/zslayton/experiment_wasm/jcotest/ionxl/wit/world.wit:5:12
|
5 | import wasi:filesystem/filesystem;
| ^--------------
If you think adding detail to an error message would be an approachable first issue, I'd be happy to give it a shot!
Last updated: Jan 24 2025 at 00:11 UTC