3524c3ef43
If a comma in a format call is replaced with a similar token, then we emit an error and continue parsing, instead of stopping at this point.
30 lines
943 B
Rust
30 lines
943 B
Rust
// Allows to track issue #75492:
|
|
// https://github.com/rust-lang/rust/issues/75492
|
|
|
|
use std::iter;
|
|
|
|
fn main() {
|
|
format!("A number: {}". iter::once(42).next().unwrap());
|
|
//~^ ERROR expected `,`, found `.`
|
|
|
|
// Other kind of types are also checked:
|
|
|
|
format!("A number: {}" / iter::once(42).next().unwrap());
|
|
//~^ ERROR expected `,`, found `/`
|
|
|
|
format!("A number: {}"; iter::once(42).next().unwrap());
|
|
//~^ ERROR expected `,`, found `;`
|
|
|
|
// Note: this character is an COMBINING COMMA BELOW unicode char
|
|
format!("A number: {}" ̦ iter::once(42).next().unwrap());
|
|
//~^ ERROR expected `,`, found `iter`
|
|
//~^^ ERROR unknown start of token: \u{326}
|
|
|
|
// Here recovery is tested.
|
|
// If the `compile_error!` is emitted, then the parser is able to recover
|
|
// from the incorrect first separator.
|
|
format!("{}". compile_error!("fail"));
|
|
//~^ ERROR expected `,`, found `.`
|
|
//~^^ ERROR fail
|
|
}
|