mirror of
https://github.com/rust-lang/rust-clippy
synced 2024-12-18 09:03:18 +00:00
Fix missing whitespace in collapsible_else_if
suggestion
This commit is contained in:
parent
a9d31e71be
commit
14667d1474
4 changed files with 40 additions and 5 deletions
|
@ -13,13 +13,14 @@
|
||||||
//! This lint is **warn** by default
|
//! This lint is **warn** by default
|
||||||
|
|
||||||
use clippy_utils::diagnostics::{span_lint_and_sugg, span_lint_and_then};
|
use clippy_utils::diagnostics::{span_lint_and_sugg, span_lint_and_then};
|
||||||
use clippy_utils::source::{snippet_block, snippet_block_with_applicability};
|
use clippy_utils::source::{snippet, snippet_block, snippet_block_with_applicability};
|
||||||
use clippy_utils::sugg::Sugg;
|
use clippy_utils::sugg::Sugg;
|
||||||
use if_chain::if_chain;
|
use if_chain::if_chain;
|
||||||
use rustc_ast::ast;
|
use rustc_ast::ast;
|
||||||
use rustc_errors::Applicability;
|
use rustc_errors::Applicability;
|
||||||
use rustc_lint::{EarlyContext, EarlyLintPass};
|
use rustc_lint::{EarlyContext, EarlyLintPass};
|
||||||
use rustc_session::{declare_lint_pass, declare_tool_lint};
|
use rustc_session::{declare_lint_pass, declare_tool_lint};
|
||||||
|
use rustc_span::Span;
|
||||||
|
|
||||||
declare_clippy_lint! {
|
declare_clippy_lint! {
|
||||||
/// ### What it does
|
/// ### What it does
|
||||||
|
@ -102,7 +103,7 @@ impl EarlyLintPass for CollapsibleIf {
|
||||||
fn check_if(cx: &EarlyContext<'_>, expr: &ast::Expr) {
|
fn check_if(cx: &EarlyContext<'_>, expr: &ast::Expr) {
|
||||||
if let ast::ExprKind::If(check, then, else_) = &expr.kind {
|
if let ast::ExprKind::If(check, then, else_) = &expr.kind {
|
||||||
if let Some(else_) = else_ {
|
if let Some(else_) = else_ {
|
||||||
check_collapsible_maybe_if_let(cx, else_);
|
check_collapsible_maybe_if_let(cx, then.span, else_);
|
||||||
} else if let ast::ExprKind::Let(..) = check.kind {
|
} else if let ast::ExprKind::Let(..) = check.kind {
|
||||||
// Prevent triggering on `if let a = b { if c { .. } }`.
|
// Prevent triggering on `if let a = b { if c { .. } }`.
|
||||||
} else {
|
} else {
|
||||||
|
@ -119,7 +120,7 @@ fn block_starts_with_comment(cx: &EarlyContext<'_>, expr: &ast::Block) -> bool {
|
||||||
trimmed_block_text.starts_with("//") || trimmed_block_text.starts_with("/*")
|
trimmed_block_text.starts_with("//") || trimmed_block_text.starts_with("/*")
|
||||||
}
|
}
|
||||||
|
|
||||||
fn check_collapsible_maybe_if_let(cx: &EarlyContext<'_>, else_: &ast::Expr) {
|
fn check_collapsible_maybe_if_let(cx: &EarlyContext<'_>, then_span: Span, else_: &ast::Expr) {
|
||||||
if_chain! {
|
if_chain! {
|
||||||
if let ast::ExprKind::Block(ref block, _) = else_.kind;
|
if let ast::ExprKind::Block(ref block, _) = else_.kind;
|
||||||
if !block_starts_with_comment(cx, block);
|
if !block_starts_with_comment(cx, block);
|
||||||
|
@ -128,6 +129,11 @@ fn check_collapsible_maybe_if_let(cx: &EarlyContext<'_>, else_: &ast::Expr) {
|
||||||
if !else_.span.from_expansion();
|
if !else_.span.from_expansion();
|
||||||
if let ast::ExprKind::If(..) = else_.kind;
|
if let ast::ExprKind::If(..) = else_.kind;
|
||||||
then {
|
then {
|
||||||
|
// Prevent "elseif"
|
||||||
|
// Check that the "else" is followed by whitespace
|
||||||
|
let up_to_else = then_span.between(block.span);
|
||||||
|
let requires_space = if let Some(c) = snippet(cx, up_to_else, "..").chars().last() { !c.is_whitespace() } else { false };
|
||||||
|
|
||||||
let mut applicability = Applicability::MachineApplicable;
|
let mut applicability = Applicability::MachineApplicable;
|
||||||
span_lint_and_sugg(
|
span_lint_and_sugg(
|
||||||
cx,
|
cx,
|
||||||
|
@ -135,7 +141,11 @@ fn check_collapsible_maybe_if_let(cx: &EarlyContext<'_>, else_: &ast::Expr) {
|
||||||
block.span,
|
block.span,
|
||||||
"this `else { if .. }` block can be collapsed",
|
"this `else { if .. }` block can be collapsed",
|
||||||
"collapse nested if block",
|
"collapse nested if block",
|
||||||
snippet_block_with_applicability(cx, else_.span, "..", Some(block.span), &mut applicability).into_owned(),
|
format!(
|
||||||
|
"{}{}",
|
||||||
|
if requires_space { " " } else { "" },
|
||||||
|
snippet_block_with_applicability(cx, else_.span, "..", Some(block.span), &mut applicability)
|
||||||
|
),
|
||||||
applicability,
|
applicability,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -75,3 +75,10 @@ fn main() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[rustfmt::skip]
|
||||||
|
#[allow(dead_code)]
|
||||||
|
fn issue_7318() {
|
||||||
|
if true { println!("I've been resolved!")
|
||||||
|
}else if false {}
|
||||||
|
}
|
||||||
|
|
|
@ -89,3 +89,12 @@ fn main() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[rustfmt::skip]
|
||||||
|
#[allow(dead_code)]
|
||||||
|
fn issue_7318() {
|
||||||
|
if true { println!("I've been resolved!")
|
||||||
|
}else{
|
||||||
|
if false {}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -150,5 +150,14 @@ LL + println!("!")
|
||||||
LL + }
|
LL + }
|
||||||
|
|
|
|
||||||
|
|
||||||
error: aborting due to 7 previous errors
|
error: this `else { if .. }` block can be collapsed
|
||||||
|
--> $DIR/collapsible_else_if.rs:97:10
|
||||||
|
|
|
||||||
|
LL | }else{
|
||||||
|
| __________^
|
||||||
|
LL | | if false {}
|
||||||
|
LL | | }
|
||||||
|
| |_____^ help: collapse nested if block: `if false {}`
|
||||||
|
|
||||||
|
error: aborting due to 8 previous errors
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue