-
Notifications
You must be signed in to change notification settings - Fork 1.8k
Open
Labels
C-bugCategory: Clippy is not doing the correct thingCategory: Clippy is not doing the correct thingI-suggestion-causes-errorIssue: The suggestions provided by this Lint cause an ICE/error when appliedIssue: The suggestions provided by this Lint cause an ICE/error when appliedP-lowPriority: LowPriority: Low
Description
Using the following flags
--force-warn clippy::redundant-else
this code:
pub fn foo<P: ?Sized>() -> &'static isize {
if false {
static a: isize = 4;
if false {
static a: isize = 4;
return &a;
} else {
static a: isize = 5;
return &a;
}
} else {
static a: isize = 5;
return &a;
}
}
pub fn bar() -> &'static isize {
foo::<isize>()
}caused the following diagnostics:
Checking _45633816536bcb2ed004a146e225178f170fb852 v0.1.0 (/tmp/icemaker_global_tempdir.tMrpGeJ6WWUI/icemaker_clippyfix_tempdir.FuaahGfV2Y1d/_45633816536bcb2ed004a146e225178f170fb852)
warning: redundant else block
--> src/lib.rs:11:6
|
11 | } else {
| ______^
12 | | static a: isize = 5;
13 | | return &a;
14 | | }
| |_____^
|
= help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_else
= note: requested on the command line with `--force-warn clippy::redundant-else`
help: remove the `else` block and move the contents out
|
11 ~ }
12 + static a: isize = 5;
13 + return &a;
|
warning: redundant else block
--> src/lib.rs:7:6
|
7 | } else {
| ______^
8 | | static a: isize = 5;
9 | | return &a;
10 | | }
| |_____^
|
= help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_else
help: remove the `else` block and move the contents out
|
7 ~ }
8 + static a: isize = 5;
9 + return &a;
|
warning: `_45633816536bcb2ed004a146e225178f170fb852` (lib) generated 2 warnings (run `cargo clippy --fix --lib -p _45633816536bcb2ed004a146e225178f170fb852` to apply 2 suggestions)
Finished `dev` profile [unoptimized + debuginfo] target(s) in 0.22s
However after applying these diagnostics, the resulting code:
pub fn foo<P: ?Sized>() -> &'static isize {
if false {
static a: isize = 4;
if false {
static a: isize = 4;
return &a;
}
static a: isize = 5;
return &a;
}
static a: isize = 5;
return &a;
}
pub fn bar() -> &'static isize {
foo::<isize>()
}no longer compiled:
Checking _45633816536bcb2ed004a146e225178f170fb852 v0.1.0 (/tmp/icemaker_global_tempdir.tMrpGeJ6WWUI/icemaker_clippyfix_tempdir.FuaahGfV2Y1d/_45633816536bcb2ed004a146e225178f170fb852)
error[E0428]: the name `a` is defined multiple times
--> src/lib.rs:8:9
|
3 | static a: isize = 4;
| -------------------- previous definition of the value `a` here
...
8 | static a: isize = 5;
| ^^^^^^^^^^^^^^^^^^^^ `a` redefined here
|
= note: `a` must be defined only once in the value namespace of this block
For more information about this error, try `rustc --explain E0428`.
error: could not compile `_45633816536bcb2ed004a146e225178f170fb852` (lib) due to 1 previous error
warning: build failed, waiting for other jobs to finish...
error: could not compile `_45633816536bcb2ed004a146e225178f170fb852` (lib test) due to 1 previous error
Version:
rustc 1.93.0-nightly (6a884ad1b 2025-11-02)
binary: rustc
commit-hash: 6a884ad1b502fe48307d363858510702429fc735
commit-date: 2025-11-02
host: x86_64-unknown-linux-gnu
release: 1.93.0-nightly
LLVM version: 21.1.3
Metadata
Metadata
Assignees
Labels
C-bugCategory: Clippy is not doing the correct thingCategory: Clippy is not doing the correct thingI-suggestion-causes-errorIssue: The suggestions provided by this Lint cause an ICE/error when appliedIssue: The suggestions provided by this Lint cause an ICE/error when appliedP-lowPriority: LowPriority: Low