// FIXME: Ideally these suggestions would be fixed via rustfix. Blocked by rust-lang/rust#53934
// // run-rustfix

#![allow(clippy::write_literal)]
#![warn(clippy::write_with_newline)]

use std::io::Write;

fn main() {
    let mut v = Vec::new();

    // These should fail
    write!(&mut v, "Hello\n");
    write!(&mut v, "Hello {}\n", "world");
    write!(&mut v, "Hello {} {}\n", "world", "#2");
    write!(&mut v, "{}\n", 1265);
    write!(&mut v, "\n");

    // These should be fine
    write!(&mut v, "");
    write!(&mut v, "Hello");
    writeln!(&mut v, "Hello");
    writeln!(&mut v, "Hello\n");
    writeln!(&mut v, "Hello {}\n", "world");
    write!(&mut v, "Issue\n{}", 1265);
    write!(&mut v, "{}", 1265);
    write!(&mut v, "\n{}", 1275);
    write!(&mut v, "\n\n");
    write!(&mut v, "like eof\n\n");
    write!(&mut v, "Hello {} {}\n\n", "world", "#2");
    writeln!(&mut v, "\ndon't\nwarn\nfor\nmultiple\nnewlines\n"); // #3126
    writeln!(&mut v, "\nbla\n\n"); // #3126

    // Escaping
    write!(&mut v, "\\n"); // #3514
    write!(&mut v, "\\\n"); // should fail
    write!(&mut v, "\\\\n");

    // Raw strings
    write!(&mut v, r"\n"); // #3778

    // Literal newlines should also fail
    write!(
        &mut v,
        "
"
    );
    write!(
        &mut v,
        r"
"
    );

    // Don't warn on CRLF (#4208)
    write!(&mut v, "\r\n");
    write!(&mut v, "foo\r\n");
    write!(&mut v, "\\r\n"); //~ ERROR
    write!(&mut v, "foo\rbar\n");
}