-
Notifications
You must be signed in to change notification settings - Fork 20
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add array::try_from_iter
as safe way of creating a fixed sized array
from an IntoIterator
.
#229
Comments
What is the benefit of this over just How far is |
at least to me, it seems that a dedicated function in granted, the proposed function is still called then again, this is just my intuition, and since this is quite subjective, others may feel completely different about this! for example, @scottmcm raised some really good points against it here!
i am actually not quite sure about this part! it looks like it's in final comment period (telling you about this feels a bit silly @pitaj hehe) which seems like it may come to a close quite soon ! :D |
We discussed this during today's libs-api meeting. We're generally in favor of having iterator -> array conversion APIs. But we're not convinced that this particular proposal is the right approach. One of the concerns was its error handling, whether it should behave more like There are lots of possible signatures discussed in #81615 of which more than one likely is useful (similar to About Marking this ACP as accepted in the sense that we do want conversion APIs. But we also think further discussion (e.g. on the internals forum) is needed to find the right set of APIs, so the linked PR shouldn't necessarily land as proposed. |
Heyy @the8472, thank you so much for giving so much detail on why you and the team came to this decision! in retrospect, and considering everything you mentioned, it does make a lot of sense to decide against adding this API! this i totally must concede! you are very right, in that it does not really add much new functionality or poses as a truly novel API. yet, it really does mostly expose something that already exists and is not too difficult at all to access! your final remark on further discussion being needed seems extremely true, and having an extended conversation about how to possibly have something like this in the future! this decision that you made here makes total sense, i think ! thank you for giving it this much time and consideration ! :)) |
Proposal
This feature aims to introduce a standard way of fallibly creating a
[T; N]
from anIntoIterator<Item = T>
. It functions by passing anIntoIterator<Item = T>
which will result in a[T; N]
, if and only if theIntoIterator
holds>= N
items. Otherwise, it returns anarray::IntoIter<T>
with the originalIntoIterator
's items. The proposed method signature follows:Problem statement
In cases in which we want to construct a fixed-size array from a collection or iterator we currently
do not have a standard and safe way of doing so. While it is possible to do this without additional
allocation, this requires some use of
unsafe
and thus leaves the implementer with more room for errorand potential
UB
.There has been much work done on fallible
Iterator
methods such astry_collect
andtry_fold
, andmore work that is being undertaken to stabilize things like
try_process
, these do not strictly apply tothis. The purpose of this API is creating a fixed-size array from an iterator where the failure case does
not come from the
Iterator
'sItem
s, but solely from theIterator
not holding enoughItem
s.Therefore, it seems like giving array a dedicated associated method that narrows the scope of failure
to the relationship between the size of the
Iterator
and the size of the array would be the pragmaticthing to do.
Additionally, the relatively recent addition of
iter:next_chunk
means this implements basically for free.
Motivation, use-cases
array::try_from_iter
provides a safe API for creating fixed-size arrays[T; N]
fromIntoIterator
s.For a somewhat contrived example, say we want to create a
[String; 32]
from aHashSet<String>
.Oftentimes it can be more efficient to deal with fixed-size arrays, as they do away with the inherent
indirection that come with many of the other collection types. This means arrays can be great when
lookup speeds are of high importance. The problem is that Rust does not make it particularly easy to
dynamically allocate fixed-size arrays at runtime without the use of
unsafe
code. This feature allowsdevelopers to turn their collections into fixed-size arrays of specified size in a safe and ergonomic
manner.
Naturally it can be the case that a collection or
IntoIterator
does not hold enough elements to fill theentire length of the array. If that happens
try_from_iter
returns anarray::IntoIter
that that holdsthe elements of the original
IntoIterator
.As this change is additive its adaptation should be quite straight forward. There may of course an
argument to be made for choosing a different name with better discoverability.
The addition of any methods that can replace existing
unsafe
code in crates should be an improvement, atleast as it pertains to safety.
Solution sketches
The implementation of this feature should be quite straight forward as it is essentially a wrapper around
iter::next_chunk
:It turns the passed type/collection into
iter
, anIterator<Item = T>
and then callsnext_chunk
.Links and related work
What happens now?
This issue is part of the libs-api team API change proposal process. Once this issue is filed the libs-api team will review open proposals in its weekly meeting. You should receive feedback within a week or two.
The text was updated successfully, but these errors were encountered: