mirror of
https://github.com/rust-lang/rust.git
synced 2025-01-23 21:23:20 +00:00
ef38662d04
* Replace variables inside | patterns in the if let: let v = if let V::A(v) | V::B(v) = v { v } else ... * Support nested patterns: let v = if let Ok(Ok(Ok(v))) = v { v } else ... * Support tuple structs with more than one arg: let v = V::W(v, _) = v { v } else ... * Correctly handle .. in tuple struct patterns: let v = V::X(v, ..) = v { v } else ...
308 lines
8.3 KiB
Plaintext
308 lines
8.3 KiB
Plaintext
error: this could be rewritten as `let...else`
|
|
--> $DIR/manual_let_else.rs:24:5
|
|
|
|
|
LL | let v = if let Some(v_some) = g() { v_some } else { return };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: consider writing: `let Some(v) = g() else { return };`
|
|
|
|
|
= note: `-D clippy::manual-let-else` implied by `-D warnings`
|
|
|
|
error: this could be rewritten as `let...else`
|
|
--> $DIR/manual_let_else.rs:25:5
|
|
|
|
|
LL | / let v = if let Some(v_some) = g() {
|
|
LL | | v_some
|
|
LL | | } else {
|
|
LL | | return;
|
|
LL | | };
|
|
| |______^
|
|
|
|
|
help: consider writing
|
|
|
|
|
LL ~ let Some(v) = g() else {
|
|
LL + return;
|
|
LL + };
|
|
|
|
|
|
|
error: this could be rewritten as `let...else`
|
|
--> $DIR/manual_let_else.rs:31:5
|
|
|
|
|
LL | / let v = if let Some(v) = g() {
|
|
LL | | // Blocks around the identity should have no impact
|
|
LL | | {
|
|
LL | | { v }
|
|
... |
|
|
LL | | return;
|
|
LL | | };
|
|
| |______^
|
|
|
|
|
help: consider writing
|
|
|
|
|
LL ~ let Some(v) = g() else {
|
|
LL + // Some computation should still make it fire
|
|
LL + g();
|
|
LL + return;
|
|
LL + };
|
|
|
|
|
|
|
error: this could be rewritten as `let...else`
|
|
--> $DIR/manual_let_else.rs:44:9
|
|
|
|
|
LL | let v = if let Some(v_some) = g() { v_some } else { continue };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: consider writing: `let Some(v) = g() else { continue };`
|
|
|
|
error: this could be rewritten as `let...else`
|
|
--> $DIR/manual_let_else.rs:45:9
|
|
|
|
|
LL | let v = if let Some(v_some) = g() { v_some } else { break };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: consider writing: `let Some(v) = g() else { break };`
|
|
|
|
error: this could be rewritten as `let...else`
|
|
--> $DIR/manual_let_else.rs:49:5
|
|
|
|
|
LL | let v = if let Some(v_some) = g() { v_some } else { panic!() };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: consider writing: `let Some(v) = g() else { panic!() };`
|
|
|
|
error: this could be rewritten as `let...else`
|
|
--> $DIR/manual_let_else.rs:52:5
|
|
|
|
|
LL | / let v = if let Some(v_some) = g() {
|
|
LL | | v_some
|
|
LL | | } else {
|
|
LL | | std::process::abort()
|
|
LL | | };
|
|
| |______^
|
|
|
|
|
help: consider writing
|
|
|
|
|
LL ~ let Some(v) = g() else {
|
|
LL + std::process::abort()
|
|
LL + };
|
|
|
|
|
|
|
error: this could be rewritten as `let...else`
|
|
--> $DIR/manual_let_else.rs:59:5
|
|
|
|
|
LL | / let v = if let Some(v_some) = g() {
|
|
LL | | v_some
|
|
LL | | } else {
|
|
LL | | if true { return } else { panic!() }
|
|
LL | | };
|
|
| |______^
|
|
|
|
|
help: consider writing
|
|
|
|
|
LL ~ let Some(v) = g() else {
|
|
LL + if true { return } else { panic!() }
|
|
LL + };
|
|
|
|
|
|
|
error: this could be rewritten as `let...else`
|
|
--> $DIR/manual_let_else.rs:66:5
|
|
|
|
|
LL | / let v = if let Some(v_some) = g() {
|
|
LL | | v_some
|
|
LL | | } else {
|
|
LL | | if true {}
|
|
LL | | panic!();
|
|
LL | | };
|
|
| |______^
|
|
|
|
|
help: consider writing
|
|
|
|
|
LL ~ let Some(v) = g() else {
|
|
LL + if true {}
|
|
LL + panic!();
|
|
LL + };
|
|
|
|
|
|
|
error: this could be rewritten as `let...else`
|
|
--> $DIR/manual_let_else.rs:76:5
|
|
|
|
|
LL | / let v = if let Some(v_some) = g() {
|
|
LL | | v_some
|
|
LL | | } else {
|
|
LL | | match () {
|
|
... |
|
|
LL | | }
|
|
LL | | };
|
|
| |______^
|
|
|
|
|
help: consider writing
|
|
|
|
|
LL ~ let Some(v) = g() else {
|
|
LL + match () {
|
|
LL + _ if panic!() => {},
|
|
LL + _ => panic!(),
|
|
LL + }
|
|
LL + };
|
|
|
|
|
|
|
error: this could be rewritten as `let...else`
|
|
--> $DIR/manual_let_else.rs:86:5
|
|
|
|
|
LL | let v = if let Some(v_some) = g() { v_some } else { if panic!() {} };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: consider writing: `let Some(v) = g() else { if panic!() {} };`
|
|
|
|
error: this could be rewritten as `let...else`
|
|
--> $DIR/manual_let_else.rs:89:5
|
|
|
|
|
LL | / let v = if let Some(v_some) = g() {
|
|
LL | | v_some
|
|
LL | | } else {
|
|
LL | | match panic!() {
|
|
LL | | _ => {},
|
|
LL | | }
|
|
LL | | };
|
|
| |______^
|
|
|
|
|
help: consider writing
|
|
|
|
|
LL ~ let Some(v) = g() else {
|
|
LL + match panic!() {
|
|
LL + _ => {},
|
|
LL + }
|
|
LL + };
|
|
|
|
|
|
|
error: this could be rewritten as `let...else`
|
|
--> $DIR/manual_let_else.rs:98:5
|
|
|
|
|
LL | / let v = if let Some(v_some) = g() {
|
|
LL | | v_some
|
|
LL | | } else if true {
|
|
LL | | return;
|
|
LL | | } else {
|
|
LL | | panic!("diverge");
|
|
LL | | };
|
|
| |______^
|
|
|
|
|
help: consider writing
|
|
|
|
|
LL ~ let Some(v) = g() else { if true {
|
|
LL + return;
|
|
LL + } else {
|
|
LL + panic!("diverge");
|
|
LL + } };
|
|
|
|
|
|
|
error: this could be rewritten as `let...else`
|
|
--> $DIR/manual_let_else.rs:107:5
|
|
|
|
|
LL | / let v = if let Some(v_some) = g() {
|
|
LL | | v_some
|
|
LL | | } else {
|
|
LL | | match (g(), g()) {
|
|
... |
|
|
LL | | }
|
|
LL | | };
|
|
| |______^
|
|
|
|
|
help: consider writing
|
|
|
|
|
LL ~ let Some(v) = g() else {
|
|
LL + match (g(), g()) {
|
|
LL + (Some(_), None) => return,
|
|
LL + (None, Some(_)) => {
|
|
LL + if true {
|
|
LL + return;
|
|
LL + } else {
|
|
LL + panic!();
|
|
LL + }
|
|
LL + },
|
|
LL + _ => return,
|
|
LL + }
|
|
LL + };
|
|
|
|
|
|
|
error: this could be rewritten as `let...else`
|
|
--> $DIR/manual_let_else.rs:124:5
|
|
|
|
|
LL | / let (v, w) = if let Some(v_some) = g().map(|v| (v, 42)) {
|
|
LL | | v_some
|
|
LL | | } else {
|
|
LL | | return;
|
|
LL | | };
|
|
| |______^
|
|
|
|
|
help: consider writing
|
|
|
|
|
LL ~ let Some((v, w)) = g().map(|v| (v, 42)) else {
|
|
LL + return;
|
|
LL + };
|
|
|
|
|
|
|
error: this could be rewritten as `let...else`
|
|
--> $DIR/manual_let_else.rs:131:5
|
|
|
|
|
LL | / let v = if let (Some(v_some), w_some) = (g(), 0) {
|
|
LL | | (w_some, v_some)
|
|
LL | | } else {
|
|
LL | | return;
|
|
LL | | };
|
|
| |______^
|
|
|
|
|
help: consider writing
|
|
|
|
|
LL ~ let (Some(v_some), w_some) = (g(), 0) else {
|
|
LL + return;
|
|
LL + };
|
|
|
|
|
|
|
error: this could be rewritten as `let...else`
|
|
--> $DIR/manual_let_else.rs:140:13
|
|
|
|
|
LL | let $n = if let Some(v) = $e { v } else { return };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: consider writing: `let Some($n) = g() else { return };`
|
|
...
|
|
LL | create_binding_if_some!(w, g());
|
|
| ------------------------------- in this macro invocation
|
|
|
|
|
= note: this error originates in the macro `create_binding_if_some` (in Nightly builds, run with -Z macro-backtrace for more info)
|
|
|
|
error: this could be rewritten as `let...else`
|
|
--> $DIR/manual_let_else.rs:149:5
|
|
|
|
|
LL | let v = if let Variant::A(a, 0) = e() { a } else { return };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: consider writing: `let Variant::A(v, 0) = e() else { return };`
|
|
|
|
error: this could be rewritten as `let...else`
|
|
--> $DIR/manual_let_else.rs:152:5
|
|
|
|
|
LL | let mut v = if let Variant::B(b) = e() { b } else { return };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: consider writing: `let Variant::B(mut v) = e() else { return };`
|
|
|
|
error: this could be rewritten as `let...else`
|
|
--> $DIR/manual_let_else.rs:156:5
|
|
|
|
|
LL | / let v = if let Ok(Some(Variant::B(b))) | Err(Some(Variant::A(b, _))) = nested {
|
|
LL | | b
|
|
LL | | } else {
|
|
LL | | return;
|
|
LL | | };
|
|
| |______^
|
|
|
|
|
help: consider writing
|
|
|
|
|
LL ~ let (Ok(Some(Variant::B(v))) | Err(Some(Variant::A(v, _)))) = nested else {
|
|
LL + return;
|
|
LL + };
|
|
|
|
|
|
|
error: this could be rewritten as `let...else`
|
|
--> $DIR/manual_let_else.rs:162:5
|
|
|
|
|
LL | let v = if let Variant::A(.., a) = e() { a } else { return };
|
|
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: consider writing: `let Variant::A(.., v) = e() else { return };`
|
|
|
|
error: this could be rewritten as `let...else`
|
|
--> $DIR/manual_let_else.rs:272:5
|
|
|
|
|
LL | / let _ = match ff {
|
|
LL | | Some(value) => value,
|
|
LL | | _ => macro_call!(),
|
|
LL | | };
|
|
| |______^ help: consider writing: `let Some(_) = ff else { macro_call!() };`
|
|
|
|
error: aborting due to 22 previous errors
|
|
|