diff --git a/Cargo.toml b/Cargo.toml index 3245a05ca0b..ee8eecdfeb5 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -121,7 +121,8 @@ rust_2018_idioms = "warn" # TODO: could this be removed? private_intra_doc_links = "allow" [workspace.lints.clippy] -all = { level = "allow", priority = -1 } +all = { level = "allow", priority = -2 } +correctness = { level = "warn", priority = -1 } dbg_macro = "warn" disallowed_methods = "warn" print_stderr = "warn" diff --git a/crates/cargo-util-schemas/src/manifest/mod.rs b/crates/cargo-util-schemas/src/manifest/mod.rs index 8442e62cc52..0db29ad492b 100644 --- a/crates/cargo-util-schemas/src/manifest/mod.rs +++ b/crates/cargo-util-schemas/src/manifest/mod.rs @@ -418,6 +418,13 @@ impl<'de> de::Deserialize<'de> for InheritableString { Ok(InheritableString::Value(value)) } + fn visit_str(self, value: &str) -> Result + where + E: de::Error, + { + self.visit_string(value.to_owned()) + } + fn visit_map(self, map: V) -> Result where V: de::MapAccess<'de>, @@ -454,6 +461,13 @@ impl<'de> de::Deserialize<'de> for InheritableRustVersion { Ok(InheritableRustVersion::Value(value)) } + fn visit_str(self, value: &str) -> Result + where + E: de::Error, + { + self.visit_string(value.to_owned()) + } + fn visit_map(self, map: V) -> Result where V: de::MapAccess<'de>, @@ -533,6 +547,13 @@ impl<'de> de::Deserialize<'de> for InheritableStringOrBool { StringOrBool::deserialize(string).map(InheritableField::Value) } + fn visit_str(self, value: &str) -> Result + where + E: de::Error, + { + self.visit_string(value.to_owned()) + } + fn visit_map(self, map: V) -> Result where V: de::MapAccess<'de>, diff --git a/crates/rustfix/src/replace.rs b/crates/rustfix/src/replace.rs index 3eb130203d0..f1a2e7eca2c 100644 --- a/crates/rustfix/src/replace.rs +++ b/crates/rustfix/src/replace.rs @@ -255,6 +255,7 @@ mod tests { } #[test] + #[allow(clippy::reversed_empty_ranges)] fn replace_invalid_range() { let mut d = Data::new(b"foo!"); diff --git a/src/cargo/core/resolver/dep_cache.rs b/src/cargo/core/resolver/dep_cache.rs index e0964fcc07d..7d584d2c8bd 100644 --- a/src/cargo/core/resolver/dep_cache.rs +++ b/src/cargo/core/resolver/dep_cache.rs @@ -207,7 +207,6 @@ impl<'a> RegistryQueryer<'a> { } } - let first_version = first_version; self.version_prefs.sort_summaries(&mut ret, first_version); let out = Poll::Ready(Rc::new(ret)); diff --git a/src/cargo/util/mod.rs b/src/cargo/util/mod.rs index 3236920da61..e2f32048d6e 100644 --- a/src/cargo/util/mod.rs +++ b/src/cargo/util/mod.rs @@ -176,8 +176,8 @@ mod test { ); assert_eq!(human_readable_bytes(1024 * 1024 * 1024), (1., "GiB")); assert_eq!( - human_readable_bytes((1024. * 1024. * 1024. * 3.1415) as u64), - (3.1415, "GiB") + human_readable_bytes((1024. * 1024. * 1024. * 1.2345) as u64), + (1.2345, "GiB") ); assert_eq!(human_readable_bytes(1024 * 1024 * 1024 * 1024), (1., "TiB")); assert_eq!( diff --git a/src/cargo/util/toml/mod.rs b/src/cargo/util/toml/mod.rs index edbfe996292..be8e7512776 100644 --- a/src/cargo/util/toml/mod.rs +++ b/src/cargo/util/toml/mod.rs @@ -507,7 +507,7 @@ fn normalize_toml( normalized_toml.badges = original_toml.badges.clone(); } else { - for field in original_toml.requires_package() { + if let Some(field) = original_toml.requires_package().next() { bail!("this virtual manifest specifies a `{field}` section, which is not allowed"); } }