2021-03-25 18:29:11 +00:00
|
|
|
use super::utils::get_hint_if_single_char_arg;
|
|
|
|
use clippy_utils::diagnostics::span_lint_and_sugg;
|
|
|
|
use if_chain::if_chain;
|
2021-03-12 14:30:50 +00:00
|
|
|
use rustc_errors::Applicability;
|
|
|
|
use rustc_hir as hir;
|
|
|
|
use rustc_lint::LateContext;
|
2021-03-25 18:29:11 +00:00
|
|
|
use rustc_middle::ty;
|
|
|
|
use rustc_span::symbol::Symbol;
|
2021-03-12 14:30:50 +00:00
|
|
|
|
|
|
|
use super::SINGLE_CHAR_PATTERN;
|
|
|
|
|
2021-12-06 11:33:31 +00:00
|
|
|
const PATTERN_METHODS: [(&str, usize); 24] = [
|
2021-05-06 09:51:22 +00:00
|
|
|
("contains", 1),
|
|
|
|
("starts_with", 1),
|
|
|
|
("ends_with", 1),
|
|
|
|
("find", 1),
|
|
|
|
("rfind", 1),
|
|
|
|
("split", 1),
|
2021-12-06 11:33:31 +00:00
|
|
|
("split_inclusive", 1),
|
2021-05-06 09:51:22 +00:00
|
|
|
("rsplit", 1),
|
|
|
|
("split_terminator", 1),
|
|
|
|
("rsplit_terminator", 1),
|
|
|
|
("splitn", 2),
|
|
|
|
("rsplitn", 2),
|
2021-12-06 11:33:31 +00:00
|
|
|
("split_once", 1),
|
|
|
|
("rsplit_once", 1),
|
2021-05-06 09:51:22 +00:00
|
|
|
("matches", 1),
|
|
|
|
("rmatches", 1),
|
|
|
|
("match_indices", 1),
|
|
|
|
("rmatch_indices", 1),
|
|
|
|
("strip_prefix", 1),
|
|
|
|
("strip_suffix", 1),
|
|
|
|
("trim_start_matches", 1),
|
|
|
|
("trim_end_matches", 1),
|
2021-12-06 11:33:31 +00:00
|
|
|
("replace", 1),
|
|
|
|
("replacen", 1),
|
2021-05-06 09:51:22 +00:00
|
|
|
];
|
|
|
|
|
2021-03-12 14:30:50 +00:00
|
|
|
/// lint for length-1 `str`s for methods in `PATTERN_METHODS`
|
2021-03-25 18:29:11 +00:00
|
|
|
pub(super) fn check(cx: &LateContext<'_>, _expr: &hir::Expr<'_>, method_name: Symbol, args: &[hir::Expr<'_>]) {
|
2021-05-06 09:51:22 +00:00
|
|
|
for &(method, pos) in &PATTERN_METHODS {
|
2021-03-25 18:29:11 +00:00
|
|
|
if_chain! {
|
|
|
|
if let ty::Ref(_, ty, _) = cx.typeck_results().expr_ty_adjusted(&args[0]).kind();
|
|
|
|
if *ty.kind() == ty::Str;
|
|
|
|
if method_name.as_str() == method && args.len() > pos;
|
|
|
|
let arg = &args[pos];
|
|
|
|
let mut applicability = Applicability::MachineApplicable;
|
|
|
|
if let Some(hint) = get_hint_if_single_char_arg(cx, arg, &mut applicability);
|
|
|
|
then {
|
|
|
|
span_lint_and_sugg(
|
|
|
|
cx,
|
|
|
|
SINGLE_CHAR_PATTERN,
|
|
|
|
arg.span,
|
|
|
|
"single-character string constant used as pattern",
|
|
|
|
"try using a `char` instead",
|
|
|
|
hint,
|
|
|
|
applicability,
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
2021-03-12 14:30:50 +00:00
|
|
|
}
|
|
|
|
}
|