2023-09-17 17:50:45 -04:00
|
|
|
#![warn(clippy::redundant_as_str)]
|
|
|
|
|
|
|
|
fn main() {
|
2023-09-18 16:39:09 -04:00
|
|
|
let string = "Hello, world!".to_owned();
|
2023-09-18 16:08:02 -04:00
|
|
|
|
2023-09-18 16:39:09 -04:00
|
|
|
// These methods are redundant and the `as_str` can be removed
|
2023-09-18 16:32:22 -04:00
|
|
|
let _redundant = string.as_str().as_bytes();
|
|
|
|
let _redundant = string.as_str().is_empty();
|
|
|
|
|
2023-09-18 16:37:27 -04:00
|
|
|
// These methods don't use `as_str` when they are redundant
|
2023-09-18 16:36:10 -04:00
|
|
|
let _no_as_str = string.as_bytes();
|
|
|
|
let _no_as_str = string.is_empty();
|
|
|
|
|
2023-09-18 16:39:09 -04:00
|
|
|
// These methods are not redundant, and are equivelant to
|
|
|
|
// doing dereferencing the string and applying the method
|
2023-09-18 16:32:22 -04:00
|
|
|
let _not_redundant = string.as_str().escape_unicode();
|
|
|
|
let _not_redundant = string.as_str().trim();
|
|
|
|
let _not_redundant = string.as_str().split_whitespace();
|
|
|
|
|
2023-09-18 16:39:09 -04:00
|
|
|
// These methods don't use `as_str` and are applied on a `str` directly
|
|
|
|
let borrowed_str = "Hello, world!";
|
2023-09-18 16:36:10 -04:00
|
|
|
let _is_str = borrowed_str.as_bytes();
|
|
|
|
let _is_str = borrowed_str.is_empty();
|
2023-09-17 17:50:45 -04:00
|
|
|
}
|