2022-08-02 20:37:40 +00:00
|
|
|
#![warn(clippy::collapsible_str_replace)]
|
|
|
|
|
2022-08-04 21:46:41 +00:00
|
|
|
fn get_filter() -> &'static str {
|
|
|
|
"u"
|
|
|
|
}
|
|
|
|
|
2022-08-02 20:37:40 +00:00
|
|
|
fn main() {
|
|
|
|
let misspelled = "hesuo worpd";
|
|
|
|
|
|
|
|
let p = 'p';
|
|
|
|
let s = 's';
|
|
|
|
let u = 'u';
|
2022-08-05 19:08:43 +00:00
|
|
|
let l = "l";
|
2022-08-02 20:37:40 +00:00
|
|
|
|
2022-08-04 21:46:41 +00:00
|
|
|
// LINT CASES
|
2022-08-02 20:37:40 +00:00
|
|
|
// If the first argument to a single `str::replace` call is a slice and none of the chars
|
|
|
|
// are variables, recommend `collapsible_str_replace`
|
|
|
|
let replacement = misspelled.replace(&['s', 'u', 'p'], "l");
|
|
|
|
println!("{replacement}");
|
|
|
|
|
2022-08-05 19:08:43 +00:00
|
|
|
let replacement = misspelled.replace(&['s', 'u', 'p'], l);
|
|
|
|
println!("{replacement}");
|
|
|
|
|
|
|
|
// If multiple `str::replace` calls contain slices and none of the chars are variables,
|
|
|
|
// recommend `collapsible_str_replace`
|
|
|
|
let replacement = misspelled.replace(&['s', 'u'], "l").replace(&['u', 'p'], "l");
|
|
|
|
println!("{replacement}");
|
|
|
|
|
|
|
|
let replacement = misspelled.replace('s', "l").replace(&['u', 'p'], "l");
|
|
|
|
println!("{replacement}");
|
|
|
|
|
|
|
|
let replacement = misspelled.replace(&['s', 'u'], "l").replace('p', "l");
|
|
|
|
println!("replacement");
|
|
|
|
|
2022-08-04 21:46:41 +00:00
|
|
|
// If there are consecutive calls to `str::replace` and none of the chars are variables,
|
|
|
|
// recommend `collapsible_str_replace`
|
|
|
|
let replacement = misspelled.replace('s', "l").replace('u', "l");
|
2022-08-02 20:37:40 +00:00
|
|
|
println!("{replacement}");
|
|
|
|
|
2022-08-04 21:46:41 +00:00
|
|
|
let replacement = misspelled.replace('s', "l").replace('u', "l").replace('p', "l");
|
2022-08-02 20:37:40 +00:00
|
|
|
println!("{replacement}");
|
|
|
|
|
2022-08-04 21:46:41 +00:00
|
|
|
// NO LINT CASES
|
|
|
|
// If there is a single call to `str::replace` and the first argument is a char or a variable,
|
|
|
|
// do not recommend `collapsible_str_replace`
|
2022-08-02 20:37:40 +00:00
|
|
|
let replacement = misspelled.replace('s', "l");
|
|
|
|
println!("{replacement}");
|
|
|
|
|
|
|
|
let replacement = misspelled.replace(s, "l");
|
|
|
|
println!("{replacement}");
|
|
|
|
|
2022-08-04 21:46:41 +00:00
|
|
|
// If the `from` argument is of kind other than a slice or a char, do not lint
|
|
|
|
let replacement = misspelled.replace(&get_filter(), "l");
|
|
|
|
|
|
|
|
// NO LINT TIL IMPROVEMENT
|
|
|
|
// The first iteration of `collapsible_str_replace` will not create lint if the first argument to
|
|
|
|
// a single `str::replace` call is a slice and one or more of its chars are variables
|
|
|
|
let replacement = misspelled.replace(&['s', u, 'p'], "l");
|
|
|
|
println!("{replacement}");
|
|
|
|
|
|
|
|
let replacement = misspelled.replace(&[s, u, 'p'], "l");
|
|
|
|
println!("{replacement}");
|
|
|
|
|
|
|
|
let replacement = misspelled.replace(&[s, u, p], "l");
|
|
|
|
println!("{replacement}");
|
|
|
|
|
|
|
|
let replacement = misspelled.replace(&[s, u], "l").replace(&[u, p], "l");
|
2022-08-02 20:37:40 +00:00
|
|
|
println!("{replacement}");
|
|
|
|
|
2022-08-04 21:46:41 +00:00
|
|
|
// FALLBACK CASES
|
2022-08-02 20:37:40 +00:00
|
|
|
// If there are consecutive calls to `str::replace` and all or any chars are variables,
|
|
|
|
// recommend the fallback `misspelled.replace(&[s, u, p], "l")`
|
|
|
|
let replacement = misspelled.replace(s, "l").replace('u', "l");
|
|
|
|
println!("{replacement}");
|
|
|
|
|
|
|
|
let replacement = misspelled.replace(s, "l").replace('u', "l").replace('p', "l");
|
|
|
|
println!("{replacement}");
|
|
|
|
|
|
|
|
let replacement = misspelled.replace(s, "l").replace(u, "l").replace('p', "l");
|
|
|
|
println!("{replacement}");
|
|
|
|
|
|
|
|
let replacement = misspelled.replace(s, "l").replace(u, "l").replace(p, "l");
|
|
|
|
println!("{replacement}");
|
|
|
|
}
|