-
Notifications
You must be signed in to change notification settings - Fork 13.9k
array zip_map feature #94413
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
array zip_map feature #94413
Conversation
r? @m-ou-se (rust-highfive has picked a reviewer for you, use r? to override) |
This comment has been minimized.
This comment has been minimized.
Would it be better if this |
This comment has been minimized.
This comment has been minimized.
While this seems reasonable, I'm worried about this leading us on a path towards a large amount of iterator-like functions on the array type. What are other iterator-like functions that anybody might want on the array type? Is |
That is certainly a valid point. I feel like we might have already crossed that line with the existing I'll try @slanterns suggestion and see how well it optimised with some iterator adapters. If it does optimise well, maybe we can push for |
Alternatively, my goal was to provide some convenient I thought getting this PR in would be easier than an RFC regarding implementing these traits onto arrays, but maybe I'll start the RFC now |
@conradludgate |
Still waiting for me to attempt the iterator adapter form to see if they can meet similar optimisations |
☔ The latest upstream changes (presumably #95602) made this pull request unmergeable. Please resolve the merge conflicts. |
F: FnMut(T, U) -> R, | ||
{ | ||
// If any of the items need drop, take the 'slow' path that ensures all drop | ||
// handlers are called in case of panic. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Assuming this is worth doing, I think it should happen in try_collect_into_array
instead (
rust/library/core/src/array/mod.rs
Line 794 in 9fbbe75
fn try_collect_into_array<I, T, R, const N: usize>(iter: &mut I) -> Option<R::TryType> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah, as I said in my other comment, it doesn't actually seem to do much here. Although my new private methods on IntoIter
make this much simpler to implement and share the drop checking code
I finally got some time to look into this more. I attempted adding a Similarly, adding the drop check skip code to It's a little disappointing but I guess this isn't worth it then if it can't generalise better. I'll focus on maintaining my crate |
@conradludgate |
As discussed on zulip.
Introduces a new zip method on arrays that is considerably faster than the existing methods.