-
Notifications
You must be signed in to change notification settings - Fork 13.1k
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
Change the desugaring of assert!
for better error output
#122661
base: master
Are you sure you want to change the base?
Conversation
rust-analyzer is developed in its own repository. If possible, consider making this change to rust-lang/rust-analyzer instead. cc @rust-lang/rust-analyzer The Miri subtree was changed cc @rust-lang/miri |
src/tools/miri/tests/pass/binops.rs
Outdated
assert!((() <= ())); | ||
assert!((!(() > ()))); | ||
assert!((() >= ())); | ||
assert!(!(() != ())); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
All of these are because now the unnecessary parentheses lint (correctly) triggers on assert!((expr))
.
tests/ui/issues/issue-14091-2.stderr
Outdated
error[E0600]: cannot apply unary operator `!` to type `BytePos` | ||
--> $DIR/issue-14091-2.rs:15:5 | ||
error[E0308]: mismatched types | ||
--> $DIR/issue-14091-2.rs:15:13 | ||
| | ||
LL | assert!(x, x); | ||
| ^^^^^^^^^^^^^ cannot apply unary operator `!` | ||
| | ||
note: an implementation of `Not` might be missing for `BytePos` | ||
--> $DIR/issue-14091-2.rs:6:1 | ||
| | ||
LL | pub struct BytePos(pub u32); | ||
| ^^^^^^^^^^^^^^^^^^ must implement `Not` | ||
note: the trait `Not` must be implemented | ||
--> $SRC_DIR/core/src/ops/bit.rs:LL:COL | ||
= note: this error originates in the macro `assert` (in Nightly builds, run with -Z macro-backtrace for more info) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is the best example of how this is an improvement.
This comment has been minimized.
This comment has been minimized.
ead1593
to
eb411c1
Compare
This comment has been minimized.
This comment has been minimized.
Sigh, clippy shows at least one test where a suggestion causes there to be a condition that isn't a |
This comment was marked as resolved.
This comment was marked as resolved.
This comment has been minimized.
This comment has been minimized.
Isn't this technically a breaking change for e.g. (playground): struct Booly(i32);
impl std::ops::Not for Booly {
type Output = bool;
fn not(self) -> Self::Output {
self.0 == 0
}
}
fn main() {
assert!(Booly(1), "booly booly!")
} |
At the very least, we might need to tie such a change to an edition. I am not certain whether this decision would be a T-lang matter or a T-libs-api one. I'll nominate for T-lang for now. (Namely: The question is whether we can start enforcing a rule that the first expression to @rustbot label +I-lang-nominated |
src/tools/rust-analyzer/crates/parser/test_data/parser/ok/0035_weird_exprs.rs
Outdated
Show resolved
Hide resolved
@pnkfelix we can keep the current (undocumented) behavior by making the desugaring be {
let x: bool = !!condition;
x
} instead of what this PR does: {
let x: bool = condition;
x
} I believe that would still cause errors to complain about Edit: an option would be to have an internal marker trait: use std::ops::Not;
trait CanAssert {}
impl<T: Not<Output = bool>> CanAssert for T {}
fn main() {
let _ = Box::new(true) as Box<dyn CanAssert>;
let _ = Box::new(42) as Box<dyn CanAssert>;
}
|
@estebank what about making the expansion edition-dependent? Is there precedent for that? Then, editions >= 2024 would expand to what you have proposed in the code of this PR, and editions < 2024 could expand to the |
(to answer my own question, |
c8185ea
to
07a5b21
Compare
Some changes occurred in coverage tests. cc @Zalathar |
I tried the marker trait approach for <=2021, and it kind of worked, but the diagnostics were actually worse than just doing |
This comment has been minimized.
This comment has been minimized.
Since I don't think it's been acknowledged above, for the record, this breaks the following code:
Because |
@compiler-errors that is indeed the case for 2024 onwards, not for previous editions. |
I think the critical point is whether an edition-dependent expansion is worth breaking that case (of Update: I don't know whether it is worth going through this exercise explicitly, but there is a design space here. E.g. one set of options is:
(And then there's variations thereof about how to handle editions < 2024, but that's a separate debate IMO.) |
(this is waiting for a decision from T-lang and/or T-libs regarding what interface we want to commit to for @rustbot label: +S-waiting-on-team -S-waiting-on-review |
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
This comment has been minimized.
570e144
to
f9cb49f
Compare
This comment has been minimized.
This comment has been minimized.
This comment was marked as resolved.
This comment was marked as resolved.
f9cb49f
to
5e6b1c8
Compare
assert!
expression is bool
assert!
for better error output
This comment has been minimized.
This comment has been minimized.
While working on rust-lang#122661, some of these started triggering our "unnecessary parens" lints due to a change in the `assert!` desugaring. A cursory search identified a few more. Some of these have been carried from before 1.0, were a bulk rename from the previous name of `assert!` left them in that state. I went and removed as many of these unnecessary parens as possible in order to have fewer annoyances in the future if we make the lint smarter.
Confirmed that the test failure is a miri issue. They are on top of it. |
☔ The latest upstream changes (presumably #136030) made this pull request unmergeable. Please resolve the merge conflicts. |
5e6b1c8
to
903c367
Compare
While working on rust-lang#122661, some of these started triggering our "unnecessary parens" lints due to a change in the `assert!` desugaring. A cursory search identified a few more. Some of these have been carried from before 1.0, were a bulk rename from the previous name of `assert!` left them in that state. I went and removed as many of these unnecessary parens as possible in order to have fewer annoyances in the future if we make the lint smarter.
☔ The latest upstream changes (presumably #136433) made this pull request unmergeable. Please resolve the merge conflicts. |
903c367
to
905df30
Compare
☔ The latest upstream changes (presumably #136533) made this pull request unmergeable. Please resolve the merge conflicts. |
905df30
to
1b0bcfe
Compare
This comment has been minimized.
This comment has been minimized.
While working on rust-lang#122661, some of these started triggering our "unnecessary parens" lints due to a change in the `assert!` desugaring. A cursory search identified a few more. Some of these have been carried from before 1.0, were a bulk rename from the previous name of `assert!` left them in that state. I went and removed as many of these unnecessary parens as possible in order to have fewer annoyances in the future if we make the lint smarter.
1b0bcfe
to
d03de1c
Compare
…r-errors Remove some unnecessary parens in `assert!` conditions While working on rust-lang#122661, some of these started triggering our "unnecessary parens" lints due to a change in the `assert!` desugaring. A cursory search identified a few more. Some of these have been carried from before 1.0, were a bulk rename from the previous name of `assert!` left them in that state. I went and removed as many of these unnecessary parens as possible in order to have fewer annoyances in the future if we make the lint smarter.
…r-errors Remove some unnecessary parens in `assert!` conditions While working on rust-lang#122661, some of these started triggering our "unnecessary parens" lints due to a change in the `assert!` desugaring. A cursory search identified a few more. Some of these have been carried from before 1.0, were a bulk rename from the previous name of `assert!` left them in that state. I went and removed as many of these unnecessary parens as possible in order to have fewer annoyances in the future if we make the lint smarter.
Rollup merge of rust-lang#135945 - estebank:useless-parens, r=compiler-errors Remove some unnecessary parens in `assert!` conditions While working on rust-lang#122661, some of these started triggering our "unnecessary parens" lints due to a change in the `assert!` desugaring. A cursory search identified a few more. Some of these have been carried from before 1.0, were a bulk rename from the previous name of `assert!` left them in that state. I went and removed as many of these unnecessary parens as possible in order to have fewer annoyances in the future if we make the lint smarter.
☔ The latest upstream changes (presumably #136809) made this pull request unmergeable. Please resolve the merge conflicts. |
d03de1c
to
8facdcf
Compare
☔ The latest upstream changes (presumably #137001) made this pull request unmergeable. Please resolve the merge conflicts. |
8facdcf
to
81fb39c
Compare
In the desugaring of `assert!`, we now expand to a `match` expression instead of `if !cond {..}`. The span of incorrect conditions will point only at the expression, and not the whole `assert!` invocation. ``` error[E0308]: mismatched types --> $DIR/issue-14091.rs:2:13 | LL | assert!(1,1); | ^ expected `bool`, found integer ``` We no longer mention the expression needing to implement the `Not` trait. ``` error[E0308]: mismatched types --> $DIR/issue-14091-2.rs:15:13 | LL | assert!(x, x); | ^ expected `bool`, found `BytePos` ``` `assert!(val)` now desugars to: ```rust match val { true => {}, _ => $crate::panic::panic_2021!(), } ``` Fix rust-lang#122159. We make some minor changes to some diagnostics to avoid span overlap on type mismatch or inverted "expected"/"found" on type errors. We remove some unnecessary parens from core, alloc and miri.
81fb39c
to
9955716
Compare
In the desugaring of
assert!
, we now expand to amatch
expression instead ofif !cond {..}
.The span of incorrect conditions will point only at the expression, and not the whole
assert!
invocation.We no longer mention the expression needing to implement the
Not
trait.Now
assert!(val)
desugars to:Fix #122159.