rylev opened issue #6584:
The preview 2
WasiCtx
does not expose any methods for manipulating its contents. This can lead to the user having to write very awkward and error prone looking code such as this:fn set_stdout(store: &mut Store<Context>, stdout: &WritePipe<std::io::Cursor<Vec<u8>>>) { let key = store.data().wasi.stdout; store .data_mut() .table_mut() .delete::<Box<dyn OutputStream>>(key) .unwrap(); store.data_mut().wasi.stdout = store .data_mut() .table_mut() .push_output_stream(Box::new(stdout.clone())) .unwrap(); }
Would it make sense to add methods like on preview 1's
WasiCtx
that mirror the builder methods and make it trivial to update aspects of the context? One complication to this is that many of these methods would require theStore
as well. Perhaps it would make sense to add these toWasiView
instead?Let me know what you think. I'd be happy to contribute the implementation if we can come to an agreement on if and where these methods should exist.
pchickey commented on issue #6584:
My thinking with the design of preview2's WasiCtx and WasiCtxBuilder is for the embedder to exclusively manipulate the WasiCtxBuilder, then put it inside a Store once it is complete. The wasmtime::component::bindgen trait implementations can then exclusively manipulate WasiCtx (and Table, via WasiView), because the bindings generation abstracts away the Store extraction.
I know there are some methods missing from WasiCtxBuilder, and Dan added a few of them while I was out on vacation last week.
Does that distinction make sense, and work for your application?
pchickey commented on issue #6584:
https://github.com/bytecodealliance/wasmtime/pull/6652 makes all of the WasiCtx members private, so the only way to change the value for stdout, as in your example, is when using the WasiCtxBuilder.
rylev commented on issue #6584:
I did some refactoring of the codebase that prompted this issue and was able to get things working. I think we can close this issue.
rylev closed issue #6584:
The preview 2
WasiCtx
does not expose any methods for manipulating its contents. This can lead to the user having to write very awkward and error prone looking code such as this:fn set_stdout(store: &mut Store<Context>, stdout: &WritePipe<std::io::Cursor<Vec<u8>>>) { let key = store.data().wasi.stdout; store .data_mut() .table_mut() .delete::<Box<dyn OutputStream>>(key) .unwrap(); store.data_mut().wasi.stdout = store .data_mut() .table_mut() .push_output_stream(Box::new(stdout.clone())) .unwrap(); }
Would it make sense to add methods like on preview 1's
WasiCtx
that mirror the builder methods and make it trivial to update aspects of the context? One complication to this is that many of these methods would require theStore
as well. Perhaps it would make sense to add these toWasiView
instead?Let me know what you think. I'd be happy to contribute the implementation if we can come to an agreement on if and where these methods should exist.
Last updated: Jan 24 2025 at 00:11 UTC