pchickey opened PR #2160 from pch/wasi_common_array_writer
to main
:
The args and environ methods duplicated code, so I factored it into a trait impled on
Vec<CString>
. It could easily be impled forVec<String>
if we wanted to, but there doesn't seem to be much reason to refactor it further now.As part of the factoring I added slice accessors
get
andget_range
towiggle::GuestPtr<[T]>
, which seem useful.<!--
Please ensure that the following steps are all taken care of before submitting
the PR.
[ ] This has been discussed in issue #..., or if not, please tell us why
here.[ ] A short description of what this does, why it is needed; if the
description becomes long, the matter should probably be discussed in an issue
first.[ ] This PR contains test cases, if meaningful.
- [ ] A reviewer from the core maintainer team has been assigned for this PR.
If you don't know who could review this, please indicate so. The list of
suggested reviewers on the right can help you.Please ensure all communication adheres to the code of conduct.
-->
pchickey requested iximeow for a review on PR #2160.
pchickey edited PR #2160 from pch/wasi_common_array_writer
to main
:
The args and environ methods duplicated code, so I factored it into a trait impled on
Vec<CString>
. It could easily be impled forVec<String>
if we wanted to, but there doesn't seem to be much reason to refactor it further now.As part of the factoring I added slice accessors
get
andget_range
towiggle::GuestPtr<[T]>
, which seem useful.My current goal is to make snapshots/wasi_snapshot_preview1.rs as uninteresting as possible. This was one small chunk that could be moved out.
<!--
Please ensure that the following steps are all taken care of before submitting
the PR.
[ ] This has been discussed in issue #..., or if not, please tell us why
here.[ ] A short description of what this does, why it is needed; if the
description becomes long, the matter should probably be discussed in an issue
first.[ ] This PR contains test cases, if meaningful.
- [ ] A reviewer from the core maintainer team has been assigned for this PR.
If you don't know who could review this, please indicate so. The list of
suggested reviewers on the right can help you.Please ensure all communication adheres to the code of conduct.
-->
pchickey edited PR #2160 from pch/wasi_common_array_writer
to main
:
The args and environ methods duplicated code, so I factored it into a trait impled on
Vec<CString>
. It could easily be impled forVec<String>
if we wanted to, but there doesn't seem to be much reason to refactor it further now.As part of the factoring I added slice accessors
get
andget_range
towiggle::GuestPtr<[T]>
, which seem useful.My current goal is to make snapshots/wasi_snapshot_preview1.rs as uninteresting as possible. This was one small chunk that could be moved out. We expect this code to work essentially the same across all snapshots, until interface types change the way we write arrays of strings into the guest.
<!--
Please ensure that the following steps are all taken care of before submitting
the PR.
[ ] This has been discussed in issue #..., or if not, please tell us why
here.[ ] A short description of what this does, why it is needed; if the
description becomes long, the matter should probably be discussed in an issue
first.[ ] This PR contains test cases, if meaningful.
- [ ] A reviewer from the core maintainer team has been assigned for this PR.
If you don't know who could review this, please indicate so. The list of
suggested reviewers on the right can help you.Please ensure all communication adheres to the code of conduct.
-->
pchickey edited PR #2160 from pch/wasi_common_array_writer
to main
:
The args and environ methods duplicated code, so I factored it into a trait impled on
Vec<CString>
. It could easily be impled forVec<String>
if we wanted to, but there doesn't seem to be much reason to refactor it further now.As part of the factoring I added slice accessors
get
andget_range
towiggle::GuestPtr<[T]>
, which seem useful.My current goal is to make snapshots/wasi_snapshot_preview1.rs as uninteresting as possible. This was one small chunk that could be moved out. We expect this code to work essentially the same across all snapshots, until interface types change the way we write arrays of strings into the guest.
Based on top of #2140 and #2139
<!--Please ensure that the following steps are all taken care of before submitting
the PR.
[ ] This has been discussed in issue #..., or if not, please tell us why
here.[ ] A short description of what this does, why it is needed; if the
description becomes long, the matter should probably be discussed in an issue
first.[ ] This PR contains test cases, if meaningful.
- [ ] A reviewer from the core maintainer team has been assigned for this PR.
If you don't know who could review this, please indicate so. The list of
suggested reviewers on the right can help you.Please ensure all communication adheres to the code of conduct.
-->
pchickey updated PR #2160 from pch/wasi_common_array_writer
to main
:
The args and environ methods duplicated code, so I factored it into a trait impled on
Vec<CString>
. It could easily be impled forVec<String>
if we wanted to, but there doesn't seem to be much reason to refactor it further now.As part of the factoring I added slice accessors
get
andget_range
towiggle::GuestPtr<[T]>
, which seem useful.My current goal is to make snapshots/wasi_snapshot_preview1.rs as uninteresting as possible. This was one small chunk that could be moved out. We expect this code to work essentially the same across all snapshots, until interface types change the way we write arrays of strings into the guest.
Based on top of #2140 and #2139
<!--Please ensure that the following steps are all taken care of before submitting
the PR.
[ ] This has been discussed in issue #..., or if not, please tell us why
here.[ ] A short description of what this does, why it is needed; if the
description becomes long, the matter should probably be discussed in an issue
first.[ ] This PR contains test cases, if meaningful.
- [ ] A reviewer from the core maintainer team has been assigned for this PR.
If you don't know who could review this, please indicate so. The list of
suggested reviewers on the right can help you.Please ensure all communication adheres to the code of conduct.
-->
pchickey updated PR #2160 from pch/wasi_common_array_writer
to main
:
The args and environ methods duplicated code, so I factored it into a trait impled on
Vec<CString>
. It could easily be impled forVec<String>
if we wanted to, but there doesn't seem to be much reason to refactor it further now.As part of the factoring I added slice accessors
get
andget_range
towiggle::GuestPtr<[T]>
, which seem useful.My current goal is to make snapshots/wasi_snapshot_preview1.rs as uninteresting as possible. This was one small chunk that could be moved out. We expect this code to work essentially the same across all snapshots, until interface types change the way we write arrays of strings into the guest.
Based on top of #2140 and #2139
<!--Please ensure that the following steps are all taken care of before submitting
the PR.
[ ] This has been discussed in issue #..., or if not, please tell us why
here.[ ] A short description of what this does, why it is needed; if the
description becomes long, the matter should probably be discussed in an issue
first.[ ] This PR contains test cases, if meaningful.
- [ ] A reviewer from the core maintainer team has been assigned for this PR.
If you don't know who could review this, please indicate so. The list of
suggested reviewers on the right can help you.Please ensure all communication adheres to the code of conduct.
-->
pchickey has marked PR #2160 as ready for review.
pchickey updated PR #2160 from pch/wasi_common_array_writer
to main
:
The args and environ methods duplicated code, so I factored it into a trait impled on
Vec<CString>
. It could easily be impled forVec<String>
if we wanted to, but there doesn't seem to be much reason to refactor it further now.As part of the factoring I added slice accessors
get
andget_range
towiggle::GuestPtr<[T]>
, which seem useful.My current goal is to make snapshots/wasi_snapshot_preview1.rs as uninteresting as possible. This was one small chunk that could be moved out. We expect this code to work essentially the same across all snapshots, until interface types change the way we write arrays of strings into the guest.
Based on top of #2140 and #2139
<!--Please ensure that the following steps are all taken care of before submitting
the PR.
[ ] This has been discussed in issue #..., or if not, please tell us why
here.[ ] A short description of what this does, why it is needed; if the
description becomes long, the matter should probably be discussed in an issue
first.[ ] This PR contains test cases, if meaningful.
- [ ] A reviewer from the core maintainer team has been assigned for this PR.
If you don't know who could review this, please indicate so. The list of
suggested reviewers on the right can help you.Please ensure all communication adheres to the code of conduct.
-->
pchickey updated PR #2160 from pch/wasi_common_array_writer
to main
:
The args and environ methods duplicated code, so I factored it into a trait impled on
Vec<CString>
. It could easily be impled forVec<String>
if we wanted to, but there doesn't seem to be much reason to refactor it further now.As part of the factoring I added slice accessors
get
andget_range
towiggle::GuestPtr<[T]>
, which seem useful.My current goal is to make snapshots/wasi_snapshot_preview1.rs as uninteresting as possible. This was one small chunk that could be moved out. We expect this code to work essentially the same across all snapshots, until interface types change the way we write arrays of strings into the guest.
Based on top of #2140 and #2139
<!--Please ensure that the following steps are all taken care of before submitting
the PR.
[ ] This has been discussed in issue #..., or if not, please tell us why
here.[ ] A short description of what this does, why it is needed; if the
description becomes long, the matter should probably be discussed in an issue
first.[ ] This PR contains test cases, if meaningful.
- [ ] A reviewer from the core maintainer team has been assigned for this PR.
If you don't know who could review this, please indicate so. The list of
suggested reviewers on the right can help you.Please ensure all communication adheres to the code of conduct.
-->
pchickey updated PR #2160 from pch/wasi_common_array_writer
to main
:
The args and environ methods duplicated code, so I factored it into a trait impled on
Vec<CString>
. It could easily be impled forVec<String>
if we wanted to, but there doesn't seem to be much reason to refactor it further now.As part of the factoring I added slice accessors
get
andget_range
towiggle::GuestPtr<[T]>
, which seem useful.My current goal is to make snapshots/wasi_snapshot_preview1.rs as uninteresting as possible. This was one small chunk that could be moved out. We expect this code to work essentially the same across all snapshots, until interface types change the way we write arrays of strings into the guest.
Based on top of #2140 and #2139
<!--Please ensure that the following steps are all taken care of before submitting
the PR.
[ ] This has been discussed in issue #..., or if not, please tell us why
here.[ ] A short description of what this does, why it is needed; if the
description becomes long, the matter should probably be discussed in an issue
first.[ ] This PR contains test cases, if meaningful.
- [ ] A reviewer from the core maintainer team has been assigned for this PR.
If you don't know who could review this, please indicate so. The list of
suggested reviewers on the right can help you.Please ensure all communication adheres to the code of conduct.
-->
pchickey edited PR #2160 from pch/wasi_common_array_writer
to main
:
The args and environ methods duplicated code, so I factored it into a trait impled on
Vec<CString>
. It could easily be impled forVec<String>
if we wanted to, but there doesn't seem to be much reason to refactor it further now.As part of the factoring I added slice accessors
get
andget_range
towiggle::GuestPtr<[T]>
, which seem useful.My current goal is to make snapshots/wasi_snapshot_preview1.rs as uninteresting as possible. This was one small chunk that could be moved out. We expect this code to work essentially the same across all snapshots, until interface types change the way we write arrays of strings into the guest.
<!--
Please ensure that the following steps are all taken care of before submitting
the PR.
[ ] This has been discussed in issue #..., or if not, please tell us why
here.[ ] A short description of what this does, why it is needed; if the
description becomes long, the matter should probably be discussed in an issue
first.[ ] This PR contains test cases, if meaningful.
- [ ] A reviewer from the core maintainer team has been assigned for this PR.
If you don't know who could review this, please indicate so. The list of
suggested reviewers on the right can help you.Please ensure all communication adheres to the code of conduct.
-->
pchickey updated PR #2160 from pch/wasi_common_array_writer
to main
:
The args and environ methods duplicated code, so I factored it into a trait impled on
Vec<CString>
. It could easily be impled forVec<String>
if we wanted to, but there doesn't seem to be much reason to refactor it further now.As part of the factoring I added slice accessors
get
andget_range
towiggle::GuestPtr<[T]>
, which seem useful.My current goal is to make snapshots/wasi_snapshot_preview1.rs as uninteresting as possible. This was one small chunk that could be moved out. We expect this code to work essentially the same across all snapshots, until interface types change the way we write arrays of strings into the guest.
<!--
Please ensure that the following steps are all taken care of before submitting
the PR.
[ ] This has been discussed in issue #..., or if not, please tell us why
here.[ ] A short description of what this does, why it is needed; if the
description becomes long, the matter should probably be discussed in an issue
first.[ ] This PR contains test cases, if meaningful.
- [ ] A reviewer from the core maintainer team has been assigned for this PR.
If you don't know who could review this, please indicate so. The list of
suggested reviewers on the right can help you.Please ensure all communication adheres to the code of conduct.
-->
alexcrichton submitted PR Review.
alexcrichton created PR Review Comment:
Should this be
index
times the gues size ofT
?
alexcrichton submitted PR Review.
alexcrichton created PR Review Comment:
Same question as above with
get
alexcrichton created PR Review Comment:
I think this may also want to include the condition that
r.start <= r.end
?
alexcrichton created PR Review Comment:
How come this is a trait? Could this perhaps be a free-function in a utils-like module of some kind?
pchickey updated PR #2160 from pch/wasi_common_array_writer
to main
:
The args and environ methods duplicated code, so I factored it into a trait impled on
Vec<CString>
. It could easily be impled forVec<String>
if we wanted to, but there doesn't seem to be much reason to refactor it further now.As part of the factoring I added slice accessors
get
andget_range
towiggle::GuestPtr<[T]>
, which seem useful.My current goal is to make snapshots/wasi_snapshot_preview1.rs as uninteresting as possible. This was one small chunk that could be moved out. We expect this code to work essentially the same across all snapshots, until interface types change the way we write arrays of strings into the guest.
<!--
Please ensure that the following steps are all taken care of before submitting
the PR.
[ ] This has been discussed in issue #..., or if not, please tell us why
here.[ ] A short description of what this does, why it is needed; if the
description becomes long, the matter should probably be discussed in an issue
first.[ ] This PR contains test cases, if meaningful.
- [ ] A reviewer from the core maintainer team has been assigned for this PR.
If you don't know who could review this, please indicate so. The list of
suggested reviewers on the right can help you.Please ensure all communication adheres to the code of conduct.
-->
pchickey submitted PR Review.
pchickey created PR Review Comment:
My thought was we would eventually support different representations than
Vec<CString>
here as part of modularization. It seemed like a reasonable way to hang three methods onto some existing struct members. But maybe instead ofWasiCtx { args: Vec<CString>, env: Vec<CString> }
we could make thisstruct StringArray(Vec<String>)
that just has these three pub methods?
pchickey submitted PR Review.
pchickey created PR Review Comment:
I was under the mistaken impression that this was guaranteed by Range construction, I'll correct that
pchickey submitted PR Review.
pchickey created PR Review Comment:
len() is in
units
(correcting this toelements
in the doc strings, not bytes, so I dont think we need to multiply by the size.
pchickey updated PR #2160 from pch/wasi_common_array_writer
to main
:
The args and environ methods duplicated code, so I factored it into a trait impled on
Vec<CString>
. It could easily be impled forVec<String>
if we wanted to, but there doesn't seem to be much reason to refactor it further now.As part of the factoring I added slice accessors
get
andget_range
towiggle::GuestPtr<[T]>
, which seem useful.My current goal is to make snapshots/wasi_snapshot_preview1.rs as uninteresting as possible. This was one small chunk that could be moved out. We expect this code to work essentially the same across all snapshots, until interface types change the way we write arrays of strings into the guest.
<!--
Please ensure that the following steps are all taken care of before submitting
the PR.
[ ] This has been discussed in issue #..., or if not, please tell us why
here.[ ] A short description of what this does, why it is needed; if the
description becomes long, the matter should probably be discussed in an issue
first.[ ] This PR contains test cases, if meaningful.
- [ ] A reviewer from the core maintainer team has been assigned for this PR.
If you don't know who could review this, please indicate so. The list of
suggested reviewers on the right can help you.Please ensure all communication adheres to the code of conduct.
-->
pchickey updated PR #2160 from pch/wasi_common_array_writer
to main
:
The args and environ methods duplicated code, so I factored it into a trait impled on
Vec<CString>
. It could easily be impled forVec<String>
if we wanted to, but there doesn't seem to be much reason to refactor it further now.As part of the factoring I added slice accessors
get
andget_range
towiggle::GuestPtr<[T]>
, which seem useful.My current goal is to make snapshots/wasi_snapshot_preview1.rs as uninteresting as possible. This was one small chunk that could be moved out. We expect this code to work essentially the same across all snapshots, until interface types change the way we write arrays of strings into the guest.
<!--
Please ensure that the following steps are all taken care of before submitting
the PR.
[ ] This has been discussed in issue #..., or if not, please tell us why
here.[ ] A short description of what this does, why it is needed; if the
description becomes long, the matter should probably be discussed in an issue
first.[ ] This PR contains test cases, if meaningful.
- [ ] A reviewer from the core maintainer team has been assigned for this PR.
If you don't know who could review this, please indicate so. The list of
suggested reviewers on the right can help you.Please ensure all communication adheres to the code of conduct.
-->
pchickey updated PR #2160 from pch/wasi_common_array_writer
to main
:
The args and environ methods duplicated code, so I factored it into a trait impled on
Vec<CString>
. It could easily be impled forVec<String>
if we wanted to, but there doesn't seem to be much reason to refactor it further now.As part of the factoring I added slice accessors
get
andget_range
towiggle::GuestPtr<[T]>
, which seem useful.My current goal is to make snapshots/wasi_snapshot_preview1.rs as uninteresting as possible. This was one small chunk that could be moved out. We expect this code to work essentially the same across all snapshots, until interface types change the way we write arrays of strings into the guest.
<!--
Please ensure that the following steps are all taken care of before submitting
the PR.
[ ] This has been discussed in issue #..., or if not, please tell us why
here.[ ] A short description of what this does, why it is needed; if the
description becomes long, the matter should probably be discussed in an issue
first.[ ] This PR contains test cases, if meaningful.
- [ ] A reviewer from the core maintainer team has been assigned for this PR.
If you don't know who could review this, please indicate so. The list of
suggested reviewers on the right can help you.Please ensure all communication adheres to the code of conduct.
-->
alexcrichton submitted PR Review.
alexcrichton submitted PR Review.
alexcrichton created PR Review Comment:
Yeah the length is in units but the
GuestPtr
returned here I think is offset in bytes from the memory base?
pchickey submitted PR Review.
pchickey created PR Review Comment:
Thanks, I completely missed that. Clearly I'm not smart enough to write or maintain this code without tests, and since the only ones i have currently are in wasi-common and use
GuestPtr<[u8]>
, ill add some others to the wiggle tree that use non-byte-sized elements and make sure its done right.
pchickey updated PR #2160 from pch/wasi_common_array_writer
to main
:
The args and environ methods duplicated code, so I factored it into a trait impled on
Vec<CString>
. It could easily be impled forVec<String>
if we wanted to, but there doesn't seem to be much reason to refactor it further now.As part of the factoring I added slice accessors
get
andget_range
towiggle::GuestPtr<[T]>
, which seem useful.My current goal is to make snapshots/wasi_snapshot_preview1.rs as uninteresting as possible. This was one small chunk that could be moved out. We expect this code to work essentially the same across all snapshots, until interface types change the way we write arrays of strings into the guest.
<!--
Please ensure that the following steps are all taken care of before submitting
the PR.
[ ] This has been discussed in issue #..., or if not, please tell us why
here.[ ] A short description of what this does, why it is needed; if the
description becomes long, the matter should probably be discussed in an issue
first.[ ] This PR contains test cases, if meaningful.
- [ ] A reviewer from the core maintainer team has been assigned for this PR.
If you don't know who could review this, please indicate so. The list of
suggested reviewers on the right can help you.Please ensure all communication adheres to the code of conduct.
-->
pchickey merged PR #2160.
Last updated: Jan 24 2025 at 00:11 UTC