mirror of
https://github.com/rust-lang/rust.git
synced 2025-01-10 14:57:14 +00:00
bf3ab592f0
* Don't lint on `.cloned().flatten()` when `T::Item` doesn't implement `IntoIterator` * Reduce verbosity of lint message * Narrow down the scope of the replacement range
56 lines
1.6 KiB
Rust
56 lines
1.6 KiB
Rust
// run-rustfix
|
|
#![warn(clippy::iter_overeager_cloned, clippy::redundant_clone, clippy::filter_next)]
|
|
#![allow(dead_code, clippy::let_unit_value)]
|
|
|
|
fn main() {
|
|
let vec = vec!["1".to_string(), "2".to_string(), "3".to_string()];
|
|
|
|
let _: Option<String> = vec.iter().last().cloned();
|
|
|
|
let _: Option<String> = vec.iter().chain(vec.iter()).next().cloned();
|
|
|
|
let _: usize = vec.iter().filter(|x| x == &"2").count();
|
|
|
|
let _: Vec<_> = vec.iter().take(2).cloned().collect();
|
|
|
|
let _: Vec<_> = vec.iter().skip(2).cloned().collect();
|
|
|
|
let _ = vec.iter().filter(|x| x == &"2").nth(2).cloned();
|
|
|
|
let _ = [Some(Some("str".to_string())), Some(Some("str".to_string()))]
|
|
.iter()
|
|
.flatten().cloned();
|
|
|
|
// Not implemented yet
|
|
let _ = vec.iter().cloned().filter(|x| x.starts_with('2'));
|
|
|
|
// Not implemented yet
|
|
let _ = vec.iter().cloned().map(|x| x.len());
|
|
|
|
// This would fail if changed.
|
|
let _ = vec.iter().cloned().map(|x| x + "2");
|
|
|
|
// Not implemented yet
|
|
let _ = vec.iter().cloned().find(|x| x == "2");
|
|
|
|
// Not implemented yet
|
|
let _ = vec.iter().cloned().for_each(|x| assert!(!x.is_empty()));
|
|
|
|
// Not implemented yet
|
|
let _ = vec.iter().cloned().all(|x| x.len() == 1);
|
|
|
|
// Not implemented yet
|
|
let _ = vec.iter().cloned().any(|x| x.len() == 1);
|
|
|
|
// Should probably stay as it is.
|
|
let _ = [0, 1, 2, 3, 4].iter().cloned().take(10);
|
|
|
|
// `&Range<_>` doesn't implement `IntoIterator`
|
|
let _ = [0..1, 2..5].iter().cloned().flatten();
|
|
}
|
|
|
|
// #8527
|
|
fn cloned_flatten(x: Option<&Option<String>>) -> Option<String> {
|
|
x.cloned().flatten()
|
|
}
|