One of the open questions surrounding the unstable gen {} feature is whether it should return Iterator or IntoIterator. People have had a feeling ther

The gen auto-trait problem

submited by
Style Pass
2025-01-17 06:30:05

One of the open questions surrounding the unstable gen {} feature is whether it should return Iterator or IntoIterator. People have had a feeling there might be good reasons for it to return IntoIterator, but couldn't necessarily articulate why. Which is why it was included in the "unresolved questions" section on the gen blocks RFC.

Because I'd like to see gen {} blocks stabilize sooner, I figured it would be worth spending some time looking into this question and see whether there are any reasons to pick one over the other. And I have found what I believe to be a fairly annoying issue with gen returning Iterator that I've started calling the gen auto-trait problem. In this post I'll walk through what this problem is, as well as how gen returning IntoIterator would prevent it. So without further ado, let's dive in!

The issue I've found has to do with auto-trait impls on reified gen {} instances. Take the thread::spawn API: it takes a closure which returns a type T. If you haven't seen its definition before, here it is:

Leave a Comment