At the end of my last post I mentioned that one of the main issues with the IntoIterator trait is that it’s kind of a pain to write. I wasn’t arou

Musings on iterator trait names

submited by
Style Pass
2025-01-22 15:00:08

At the end of my last post I mentioned that one of the main issues with the IntoIterator trait is that it’s kind of a pain to write. I wasn’t around when it was first introduced, but it’s not hard to tell that the original authors intended for Iterator to be the primary interface with IntoIterator being an additional convenience.

This didn’t quite turn out to be the case though, and it’s common practice to use IntoIterator in both bounds and impls. In the Rust 2024 edition we’re changing Rust’s range type to implement IntoIterator rather than Iterator. 1 And for example in Swift the equivalent trait to IntoIterator (Sequence) is the primary interface used for iteration. With the interface equivalent to Iterator (IteratorProtocol) having a much harder to use name.

Thanks to Lukas Wirth for pointing out that the range type change didn't end up making the cut for the edition. It's been a couple of months since I checked, and it seems it was removed for this edition. My understanding is that this change is still desired, and might make it in for a future edition.

Leave a Comment