rust-clippy/tests/ui/print_with_newline.fixed
2023-06-26 14:13:07 +00:00

58 lines
1.3 KiB
Rust

// FIXME: Ideally these suggestions would be fixed via rustfix. Blocked by rust-lang/rust#53934
//@run-rustfix
#![allow(clippy::print_literal)]
#![warn(clippy::print_with_newline)]
fn main() {
println!("Hello");
println!("Hello {}", "world");
println!("Hello {} {}", "world", "#2");
println!("{}", 1265);
println!();
// these are all fine
print!("");
print!("Hello");
println!("Hello");
println!("Hello\n");
println!("Hello {}\n", "world");
print!("Issue\n{}", 1265);
print!("{}", 1265);
print!("\n{}", 1275);
print!("\n\n");
print!("like eof\n\n");
print!("Hello {} {}\n\n", "world", "#2");
println!("\ndon't\nwarn\nfor\nmultiple\nnewlines\n"); // #3126
println!("\nbla\n\n"); // #3126
// Escaping
print!("\\n"); // #3514
println!("\\"); // should fail
print!("\\\\n");
// Raw strings
print!(r"\n"); // #3778
// Literal newlines should also fail
println!(
);
println!(
);
// Don't warn on CRLF (#4208)
print!("\r\n");
print!("foo\r\n");
println!("\\r"); // should fail
print!("foo\rbar\n");
// Ignore expanded format strings
macro_rules! newline {
() => {
"\n"
};
}
print!(newline!());
}