rust-clippy/tests/ui/format.fixed

88 lines
2.3 KiB
Rust
Raw Normal View History

2019-02-24 05:30:08 +00:00
// run-rustfix
#![allow(
clippy::print_literal,
clippy::redundant_clone,
clippy::to_string_in_format_args,
clippy::needless_borrow
)]
2019-02-24 05:30:08 +00:00
#![warn(clippy::useless_format)]
struct Foo(pub String);
macro_rules! foo {
2019-03-10 21:07:10 +00:00
($($t:tt)*) => (Foo(format!($($t)*)))
2019-02-24 05:30:08 +00:00
}
fn main() {
"foo".to_string();
"{}".to_string();
"{} abc {}".to_string();
r##"foo {}
" bar"##.to_string();
2019-02-24 05:30:08 +00:00
let _ = String::new();
2019-02-24 05:30:08 +00:00
"foo".to_string();
2019-03-10 21:07:10 +00:00
format!("{:?}", "foo"); // Don't warn about `Debug`.
2019-02-24 05:30:08 +00:00
format!("{:8}", "foo");
format!("{:width$}", "foo", width = 8);
2019-03-10 21:07:10 +00:00
"foo".to_string(); // Warn when the format makes no difference.
"foo".to_string(); // Warn when the format makes no difference.
2019-02-24 05:30:08 +00:00
format!("foo {}", "bar");
format!("{} bar", "foo");
let arg: String = "".to_owned();
arg.to_string();
2019-03-10 21:07:10 +00:00
format!("{:?}", arg); // Don't warn about debug.
2019-02-24 05:30:08 +00:00
format!("{:8}", arg);
format!("{:width$}", arg, width = 8);
2019-03-10 21:07:10 +00:00
arg.to_string(); // Warn when the format makes no difference.
arg.to_string(); // Warn when the format makes no difference.
2019-02-24 05:30:08 +00:00
format!("foo {}", arg);
format!("{} bar", arg);
2019-03-10 21:07:10 +00:00
// We dont want to warn for non-string args; see issue #697.
2019-02-24 05:30:08 +00:00
format!("{}", 42);
format!("{:?}", 42);
format!("{:+}", 42);
format!("foo {}", 42);
format!("{} bar", 42);
2019-03-10 21:07:10 +00:00
// We only want to warn about `format!` itself.
2019-02-24 05:30:08 +00:00
println!("foo");
println!("{}", "foo");
println!("foo {}", "foo");
println!("{}", 42);
println!("foo {}", 42);
2019-03-10 21:07:10 +00:00
// A `format!` inside a macro should not trigger a warning.
2019-02-24 05:30:08 +00:00
foo!("should not warn");
2019-03-10 21:07:10 +00:00
// Precision on string means slicing without panicking on size.
format!("{:.1}", "foo"); // Could be `"foo"[..1]`
format!("{:.10}", "foo"); // Could not be `"foo"[..10]`
2019-02-24 05:30:08 +00:00
format!("{:.prec$}", "foo", prec = 1);
format!("{:.prec$}", "foo", prec = 10);
42.to_string();
let x = std::path::PathBuf::from("/bar/foo/qux");
x.display().to_string();
2019-08-23 08:46:23 +00:00
// False positive
let a = "foo".to_string();
let _ = Some(a + "bar");
// Wrap it with braces
let v: Vec<String> = vec!["foo".to_string(), "bar".to_string()];
let _s: String = (&*v.join("\n")).to_string();
format!("prepend {:+}", "s");
// Issue #8290
let x = "foo";
let _ = x.to_string();
let _ = format!("{x:?}"); // Don't lint on debug
let _ = x.to_string();
2019-02-24 05:30:08 +00:00
}