mirror of
https://github.com/rust-lang/rust.git
synced 2025-11-25 15:58:31 +00:00
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 #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.
address review comments
22 lines
800 B
Plaintext
22 lines
800 B
Plaintext
error[E0080]: evaluation panicked: assertion failed: LANE < 4
|
|
--> $DIR/const-err-trumps-simd-err.rs:17:21
|
|
|
|
|
LL | const { assert!(LANE < 4); } // the error should be here...
|
|
| ^^^^^^^^ evaluation of `get_elem::<4>::{constant#0}` failed here
|
|
|
|
note: erroneous constant encountered
|
|
--> $DIR/const-err-trumps-simd-err.rs:17:5
|
|
|
|
|
LL | const { assert!(LANE < 4); } // the error should be here...
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
note: the above error was encountered while instantiating `fn get_elem::<4>`
|
|
--> $DIR/const-err-trumps-simd-err.rs:23:5
|
|
|
|
|
LL | get_elem::<4>(int8x4_t([0, 0, 0, 0]));
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
error: aborting due to 1 previous error
|
|
|
|
For more information about this error, try `rustc --explain E0080`.
|