-
Notifications
You must be signed in to change notification settings - Fork 12.8k
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
Stabilization proposal for #![feature(if_while_or_patterns)] #56212
Comments
Team member @Centril has proposed to merge this. The next step is review by the rest of the tagged teams:
Concerns:
Once a majority of reviewers approve (and none object), 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. |
@rfcbot concern subset-without-bindings I feel like there's little point in stabilizing this without stabilizing bindings (the Ok/Err case). What's the urgency? |
There's not an urgency per se; it's just useful to have Wrt. the subset-without bindings, I had the same reaction as you, #48215 (comment); this was then discussed by @petrochenkov (#48215 (comment)), with me being unsure in #48215 (comment), and Niko noting finally in #48215 (comment) that piecemeal stabilization seems fine. |
🔔 This is now entering its final comment period, as per the review above. 🔔 |
Is this perhaps supposed to say while | Thing::Beta(_) | Thing::Gamma = iter.next() |
@jonas-schievink yes, oops, thanks :) (edit: fixed) |
Stabilize #![feature(if_while_or_patterns)] r? @varkor Per #56212 (comment). Leading `|` is also accepted per the comment in the stabilization proposal.
Stabilized (#57532) just now so closing. |
Stabilization proposal
I propose that we stabilize
#![feature(if_while_or_patterns)]
.Originally proposed in RFC rust-lang/rfcs#2175, then amended by rust-lang/rfcs#2530, implemented (partially, see below) in #48490 by @petrochenkov, and available in nightly since ~25th February,
#![feature(if_while_or_patterns)]
permits users to write multiple "or patterns"A(x) | B
inif let
,while let
,for
expressions andlet
statements.See the motivation for an extended discussion; The primary reasons why this is useful are:
It permits more expressive and ergonomic control flow.
It is consistent with the behaviour of
match
expressions.Version target
The next version is 1.32 which goes into beta the 7th of December; It is quite possible that this will slip into 1.33 however depending on how long the review process takes.
What is stabilized
Users are now permitted to write for example:
Per rust-lang/rfcs#2530, leading vertical bars (
|
) are permitted; however, this behaviour cannot be observed on nightly right now. This is a fairly minor thing that will need to be fixed (+ test) in the stabilization PR.EDIT: A clarification: you can write
if let A(x) | B(x) = expr { ... }
. In other words, bindings do work.What is not
Users are not yet permitted to write:
if let A(0 | 1) = expr { ... }
;This is the generalization of or-patterns as provided for by RFC: Or patterns, i.e
Foo(Bar(x) | Baz(x))
rfcs#2535. @varkor is currently working on an implementation for that generalization.let Ok(x) | Err(x) = expr;
orfor Ok(x) | Err(x) in iter { ... }
.This is provided for by the RFC but the implementation was more complex so this will be implemented in the future, possibly by @varkor in the generalization.
This is a divergence from the RFC since a subset of the RFC is implemented.
The text was updated successfully, but these errors were encountered: