ajalt requested fitzgen for a review on PR #9477.
ajalt requested wasmtime-core-reviewers for a review on PR #9477.
ajalt opened PR #9477 from ajalt:wasi-preopen-dir-perms
to bytecodealliance:main
:
The current
wasi_config_preopen_dir
function does not expose thedir_perms
andfile_perms
parameters that were added topreopened_dir
. This commit adds them and updates the docs for those functions to reflect the current signature.This is a prerequisite for https://github.com/bytecodealliance/wasmtime-py/issues/251
This change isn't backwards compatible, so please let me know if there's anything I need to do differently.
alexcrichton submitted PR review:
Thanks for this! Could you also add some
#define
entries for the various flags here? Perhaps a flag-per-bit and a*_ALL
define which has everything OR'd together?Also I think it might be best to check for unknown bits in the method itself. For example using
from_bits
and translating the optional return value into an error being returned.
alexcrichton commented on PR #9477:
Oh sorry, forgot to mention, but:
This change isn't backwards compatible, so please let me know if there's anything I need to do differently.
That's ok, so no worries! We don't provide an ironclad guarantee of stability in the C API at this time, so it's ok to change it.
ajalt updated PR #9477.
ajalt created PR review comment:
I didn't see any other
#defines
for enums that I could use for a naming convention, so let me know if these should be moved or renamed.
ajalt submitted PR review.
ajalt submitted PR review.
ajalt created PR review comment:
This feels clunky, but I'm not a rust expert so if you know of a more idiomatic way of handling the error cases, I'd be happy to clean this up.
alexcrichton submitted PR review.
alexcrichton created PR review comment:
Looks good to me!
alexcrichton created PR review comment:
Oh for this I might recommend:
let dir_perms = wasmtime_wasi::DirPerms::from_bits(dir_perms) .ok_or_else(|| anyhow!("invalid directory permissions"))?;
That way you can avoid the nested closures
ajalt submitted PR review.
ajalt created PR review comment:
That's certainly cleaner! But
wasi_config_preopen_dir
returnsbool
rather than aResult
, so it doesn't appear that you can use the?
operator. Is there a way to do an unwrap / early return like that in a function that returnsbool
?
Or would it be better to change the function signature? Returning strings from a C API would require callers tofree
the returned result, but we could potentially use a numerical error code instead.
alexcrichton submitted PR review.
alexcrichton created PR review comment:
Ah excellent point! I forgot this returns
bool
, so sorry about that.For that I'd recommend a
match
-per-translation-of-config to returnfalse
early and that way it doesn't have to nest.I do like the idea of changing the function signature too. It's overdue for the WASI APIs here. In doing so though it might be best to rename and shuffle things around. For example the original intention of
wasi.h
was to become a standard API like the wasm-c-api proposal (which hasn't finished being standardized yet). In lieu of that nowadays it's probably best to rename things towasmtime_wasi_*
, move the header towasmtime/wasi.h
, and update idioms to match the rest of the C API (e.g.wasmtime_error_t*
instead ofbool
). That's a bit of a larger project though so how about we keep thebool
for now and defer this refactoring for later?
ajalt updated PR #9477.
ajalt submitted PR review.
ajalt created PR review comment:
Thanks, that's much cleaner. That's also the pattern already being used for the other parameters of the function, which I somehow didn't recognize :face_palm:. Sorry for the churn.
alexcrichton submitted PR review:
No worries!
alexcrichton merged PR #9477.
Last updated: Jan 24 2025 at 00:11 UTC