mirror of
https://github.com/rust-lang/rust.git
synced 2025-10-02 10:18:25 +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`.
|