This might be documented somewhere, but I just cannot find anything related to this:
Are paths in WASI Unix-style paths (/ separator) per spec, or does the spec make no statement about the format? Do WASI binaries usually just assume Unix-style paths?
I'm currently adding support for Windows to a runtime and am wondering if the WASI implementation needs path translation between module and host.
The path separator should be /
and there should be no drive letters etc visible. WASI programs aren't supposed to make assumptions about the existence of any files and directories other than what's passed to them as command-line arguments or env vars (though in practice many people don't care about windows and do it anyway).
I am working to make WASI programs more portable, but it remains to be seen how much I'll be able to achieve vs all the people who don't care about anything other than "faster docker".
Same here, I'm mostly interested in the portability aspect of WebAssembly/WASI.
In case it might not have been yet, it would be good to document the path separator assumption, because it is needed when implementing some of the WASI functions which resolve paths given the preopen.
Yeah. I looked into it a while ago but got bogged down by thinking about case sensitivity and Unicode normalization and ill-formed Unicode and Windows prohibited paths and special whitespace rules and wow. But you're right, it'd be good to document the things we can control better.
The wasi-testsuite repo can be a good place for developing these ideas too.
Right, there are more details to specify, but even just something simple as https://pubs.opengroup.org/onlinepubs/009695399/basedefs/xbd_chap03.html#tag_03_266 might be sufficient to clarify what the modules and runtime should do when joining path components.
Thank you for your quick response, that unblocks me and I can spend the rest of the holidays finishing Windows support and maybe even look into support for Mac OS (<10), which uses :
as a separator, haha
Dan Gohman said:
I am working to make WASI programs more portable, but it remains to be seen how much I'll be able to achieve vs all the people who don't care about anything other than "faster docker".
and for me, I want the most portable version of wasi we can make. I do NOT want an entire environment (unless I choose it!); future computing must be constrained to be more generally useful -- not bring along the entire pile of cruft from the past 50 years. Again, unless you ask nicely to do so. :-)
Just like how you have the choice to not use k8s, but while you don't necessarily like it, and you might not have built it that way yourself, you've got it, you use it, and so does everybody else? :smirk:
Dan Gohman said:
Just like how you have the choice to not use k8s, but while you don't necessarily like it, and you might not have built it that way yourself, you've got it, you use it, and so does everybody else? :smirk:
sorta. Why do you ask? :-)
Last updated: Jan 24 2025 at 00:11 UTC