-
Notifications
You must be signed in to change notification settings - Fork 13k
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 is_empty
function to ExactSizeIterator
#35428
Comments
Added reference to this issue in #35429 |
…l422 Indicate tracking issue for `exact_size_is_empty` unstability. rust-lang#35428
…l422 Indicate tracking issue for `exact_size_is_empty` unstability. rust-lang#35428
…l422 Indicate tracking issue for `exact_size_is_empty` unstability. rust-lang#35428
I wanted to use this today until I realized that it’s unstable. (I could use |
@rfcbot fcp merge Seems good to have consistency! |
Team member @alexcrichton has proposed to merge this. The next step is review by the rest of the tagged teams: No concerns currently listed. Once these reviewers reach consensus, this will enter its final comment period. If you spot a major issue that hasn't been raised at any point in this process, please speak up! See this document for info about what commands tagged team members can give me. |
@SimonSapin I'm curious, when do you use ExactSizeIterator and have the opportunity to use this? |
When using a slice or vec iterator as input for a parser, |
Aha, that explains it for me: using a specific iterator type, not using ESI generically. This method is good, reinforces existing conventions. |
🔔 This is now entering its final comment period, as per the review above. 🔔 psst @alexcrichton, I wasn't able to add the |
The final comment period is now complete. |
used in PR #37943 |
Here's a thought: Some iterators can implement a good is_empty() even if they can't do ESI or .len(). One example is |
@bluss Sorry I missed your comment when prepping the stabilization PR. My feeling is that these iterators can/should provide an inherent FWIW, it's also a longstanding desire on the lang side to have an API evolution path for splitting a trait into supertraits without breaking existing code. It's not guaranteed to happen, but that would allow us to split out |
I'm removing |
|
Both points make sense. However, without further language improvements, it will be tricky to meet those goals and the original ergonomic goal at the same time. Ideally, Alternatively, we could add the |
don't we have a backdoor for adding methods like this? trait Iterator has the method .rposition() where Self: DoubleEndedIterator |
@bluss I may be missing something, but I don't see how that helps here. To clarify, the competing goals I see are:
I don't offhand see how the trick you mention helps here; maybe you can spell it out? It's worth noting that we could provide an |
It's easier said than done, apparently. trait Iterator can get a new method, something like: fn is_empty(&self) -> bool
where Self: IsEmptyIterator; which fixes the issue with having the method in the prelude. But to arrange the right blanket implementations for IsEmptyIterator does not seem to be possible, even with the specialization features that are in nightly now. |
Did the |
@SimonSapin Yes, this ended up getting pulled from the stabilization PR and has been sitting idle since then. Needs someone to drive it to a conclusion. |
I can’t reproduce this: https://play.rust-lang.org/?version=stable&mode=debug&edition=2018&gist=cec84e30d1eedd6e5fa6933b4e1f8631 Did you mean something else? |
Ouch, it fails when the receiver of the call is a |
I assume it ends up calling |
Ah that’s a good point, presumably through |
Can you imagine a scenario where you would want to have a trait bound on |
In general, when an iterator is processed, but the last element needs to be handled differently. You can always get around this by buffering one element, e.g. using a In an application of mine for instance, I have a parser that scans log-files for various events and groups them into "runs" (i.e. events delimited by a start- and end-event). It is capable of detecting some instances of missing start- or end-events. |
Hi there, Looks like it hasn't been mentioned on this issue (afaict), so sharing a tiny problem I noticed with the current non-stabilized For a simple type, such as: pub type SomeRange = Range<usize>; When
|
Good news: |
fixes #139 ast.errors() now return an `impl ExactSizeIterator` which allows us to iterate, but also check for the `len()`. It should allow us to use `is_empty()` as well eventually, if / when rust-lang/rust#35428 lands.
fixes #139 ast.errors() now return an `impl ExactSizeIterator` which allows us to iterate, but also check for the `len()`. It should allow us to use `is_empty()` as well eventually, if / when rust-lang/rust#35428 lands.
fixes #139 ast.errors() now return an `impl ExactSizeIterator` which allows us to iterate, but also check for the `len()`. It should allow us to use `is_empty()` as well eventually, if / when rust-lang/rust#35428 lands.
fixes #139 ast.errors() now return an `Iter<'_, Error>` which allows us to iterate, but also check for the `len()`. It should allow us to use `is_empty()` as well eventually, if / when rust-lang/rust#35428 lands.
fixes #139 ast.errors() now return an `Iter<'_, Error>` which allows us to iterate, but also check for the `len()`. It should allow us to use `is_empty()` as well eventually, if / when rust-lang/rust#35428 lands.
fixes #139 ast.errors() now return an `Iter<'_, Error>` which allows us to iterate, but also check for the `len()`. It should allow us to use `is_empty()` as well eventually, if / when rust-lang/rust#35428 lands.
fixes #139 ast.errors() now return an `Iter<'_, Error>` which allows us to iterate, but also check for the `len()`. It should allow us to use `is_empty()` as well eventually, if / when rust-lang/rust#35428 lands.
fixes #139 ast.errors() now return an `Iter<'_, Error>` which allows us to iterate, but also check for the `len()`. It should allow us to use `is_empty()` as well eventually, if / when rust-lang/rust#35428 lands.
Hello hi 👋 Kindest little boop & status check - what is the status of this? The docs seem to still say this is nightly-only, experimental https://doc.rust-lang.org/std/iter/trait.ExactSizeIterator.html#method.is_empty |
@Walther I think the same "people want this on non- For now, |
An alternative for the not fast case would be to just use Maybe a version like EDIT: I actually really like this and might offer up a PR. |
So, I did the thing and offered up a |
remember to change all of these when github.com/rust-lang/rust/issues/35428 is stabilized
Tracking issue for functionality introduced in #34357
The text was updated successfully, but these errors were encountered: