-
Notifications
You must be signed in to change notification settings - Fork 12.9k
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
Tracking issue for eRFC 2497, "if- and while-let-chains, take 2", edition changes #53668
Comments
Nominating for discussion on whether we should try to do this for all editions or as exactly per the RFC (>=2018). |
We discussed in the @rust-lang/lang meeting and decided that we would first try to do this for all editions, because the belief is that in practice this will not a problem — and in general it'd be nice to avoid bifurcating our grammar in this way if we can get away with it. |
if- and while-let-chains, take 2 - edition changes Part of #53668. r? @nikomatsakis
Triage:
|
As discussed in rust-lang/rfcs#2544, I feel very uncomfortable with making breaking parser changes for existing code. I’d much prefer this only applied in Rust 2018. |
If the RFC process decided on not doing a breaking change, it seems really problematic to go back on that now. |
@rfcbot fcp merge So, there was some discussion on Discord. First off, independent of the merits of the decision, @durka is correct that we did not really follow the proper process here. We ought not to make a decision like this without an FCP to allow for public comment. Therefore, I am making a formal "move to merge" here to allow for this discussion. At the moment, the only thing that has landed is a "post-parse" check that issues errors in the event of the disallowed construction -- it'd be relatively easy to roll back if we decide to do that. (As to whether or not to do so, I find myself somewhat torn.) The rationale in the meeting was that we had plenty of evidence that there would be no crates affected by this change at all:
All in all, it did not seem necessary to gate this change on the Edition. There are some advantages to not doing so -- it reduces the code maintenance burden and removes the need to document two variants of the language. But these are more "tactical" advantages. And, of course, we can never know with 100% certainty whether anyone is affected. It would be nice to know if there are any actual crates affected by this decision (whether or not they are on crates.io). @SimonSapin is correct that we should not be cavalier about making breaking changes. |
Team member @nikomatsakis has proposed to merge this. The next step is review by the rest of the tagged teams:
No concerns currently listed. 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. |
These advantages seem to be only for compiler maintainers, who are far fewer than its users. Should we have a Priority of Constituencies similar to that of web standards?
|
I'd like to voice my general disagreement with this stance. Backwards-compatibility only if anyone speaks up isn't real backwards compatibility in my eyes. I agree with breakage for fixing soundness issues, or closing holes that the spec disallowed but where incorrectly permitted and such, but I don't feel syntax adjustments justify breaking compatibility. A crater run only covers what is on crates.io. It doesn't cover:
I would also say that calling for people to speak up in the comments of the tracking issue of an experimental RFC doesn't have much reach. What amount of work in following Rust development should be necessary to be able to rely on the backwards compatibility? I would assume the recommendaton is to regularly test on the beta channel. But that doesn't cover everywhere code might be. In the 2017 survey, 2793 people said they use stable, with only 139 using beta. I assume the ones testing beta on previous versions of their code is minimal. Since this is already used as precedent in the turbofish discussion, I hope you understand where some worry about the weight of Rusts backwards compatibility guarantees comes in. |
It also affects people who use
I don't think we should and the meaning of such priorities are not clear to me when applies to Rust.
This is all true; however, from crates.io + sourcegraph + the overall silliness of writing
This will reach TWiR soon but I'll add a note to the RFC itself :) That said; I do apologize for the process mistake made here. |
cc @nasa42, @llogiq, and @Flavsditz -- can we sneak this into TWiR issue 252 as well as TWiR issue 253? |
I meant adopting something in the same spirit, not literally this to the letter. |
It's more about the principle. Saying that Rust is backwards-compatible except for soundness fixes will simply be no longer true. I can also easily see things like I understand you expect the impact to be minimal. It is still the end of backwards compatibility as it currently stands. Trying to judge impact of breakage is to me exactly the opposite of a backwards compatibility guarantee. The fact that editions exist, the next one is right around the corner, but backwards compatibility is still being broken is kind of an alarm bell for me. I mean, what would happen if these changes are stabilized and someone in the community runs into an issue? Do they need to fix their code, or will Rust and the toolset roll back these changes? How many breakages would be required for the rollback? I would propose that "should Rust uphold backwards compatibility guarantees" should be discussed in the wider community. For a question like that even TWIR feels too small. |
@phaylon minor note, crater does test these (github is scraped for Rust repos). Doesn't discount the rest of the items though. |
I agree with @phaylon that it’s more a matter of principle and of setting a precedent than evaluating how bad the breakage will be in practice. Especially when the edition mechanism exists (and was introduce exactly for this purpose!) and provides an alternative other than "never do this at all". |
@SimonSapin The meaning of adopting such a thing is still vague and not particularly meaningful to me. For example, the guideline includes "theoretical purity" as the least important thing.
Our bar for doing backwards compatibility breaks has never been soundness fixes. |
@nasa42 Yup; however, in this case, I would like to propose an exception to the rule to rectify the process mistake. |
That's what I'm suggesting :) |
The backwards compatibility you are talking about never even started in the first place, so it could end. |
@Centril @Flavsditz added to TWiR 252 (and next issue's draft). |
@nasa42 Thank you! ❤️ |
@Centril
But also:
And from https://blog.rust-lang.org/2014/10/30/Stability.html
However, the epoch RFC has a section about "repurposing corner cases" which to me seems exactly fitting this case.
Do you have an example that isn't a bug or soundness fix? I've seen widespread belief that Rust guarantees backwards compatibility, if this is untrue we should correct that. |
If we had found crater regressions (even a single one) I would have been inclined to do this via the edition mechanism, such as we did with modules,
This probably counts: #53851 (comment) |
Why do you believe the things crater can test are enough to justify breaking backwards compatibility? Do you believe the things it can't reach, that live in different contexts, are less important?
That issue still seems to be open. Anything that got merged? I have to say, the fact that there's a third breakage coming down the line I didn't notice or know about makes this even worse. |
Also,
What will be the course of action if someone speaks up after this hits stable? |
Some more information: The HN discussion from when the stability promise came out reads to me as if people understood it as I did. I often see people make comments about Rust's backwards compatibility, for example these by @steveklabnik From this HN comment
So I wouldn't be surprised if more people had the same understanding as I have/had. |
Keeping in mind that this is a hypothetical question; this depends on a few variables:
What I would be quite opposed to is to be forced to do it in Rust 2021. As for @steveklabnik's note, I think we should make a distinction about de jure and de facto breaking changes as @dherman aptly put it. I believe what we did here constitutes a de jure breaking change, but not a de facto breaking change because I believe no one was affected by this. I would also note that by making this a 2015 breakage it is likely that the net breakage is lower than if we had done this on 2018 only as more crates can keep working on Rust 2015 and get to use the |
🔔 This is now entering its final comment period, as per the review above. 🔔 |
So...I continue to be sympathetic to the points being raised here. However, I also think that we have from the beginning of the project interpreted the term "breaking changes" in a practical way -- that is, we want to ensure "hassle free upgrades" and that "rustc will not break your code", but not necessarily "rustc will not break any code". In addition to the two semver RFCs (RFC 1105, RFC 1122) and the rustc bug fix procedure, there is other precedent. The most notable to me is RFC 599, which changed the defaults around default object lifetimes. In the process it explicitly overrode a prior RFC. Here is the text from the "drawbacks" section of that RFC:
As I said before, I think that -- procedurally -- we have not handled this very well. I wish that the RFC had originally stipulated that we make this a breaking change, for example. However, I think that making this decision via FCP on the tracking issue is also legitimate. Seperately, I think it would be useful to open an RFC that makes this "practical definition" of breaking changes more explicit and tries to narrow down and layout the criteria when what is a "breaking change" (versus a "change that theoretically breaks") -- the rustc bug fix procedure does exactly this, but in a narrower context. For the time being, though, we have to ask ourselves about where particular case falls. My sense remains that it pretty clearly falls on the "no practical breakage" side of the line and that we might as well clean it up. |
The final comment period, with a disposition to merge, as per the review above, is now complete. |
Triage: Remaining work to be done is documenting the changes made. After that we can close this issue. |
Triage: documentation to the reference was done by @davidtwco and merged. |
This is a tracking issue for the eRFC "if- and while-let-chains, take 2" (rust-lang/rfcs#2497) pertaining solely to the immediate Rust 2018 transition changes. For the main tracking issue, see #53667.
Steps:
Unresolved questions:
There are none.
The text was updated successfully, but these errors were encountered: