Be accurate on format! parse error expectations
This commit is contained in:
@@ -138,15 +138,23 @@ fn parse_args<'a>(
|
|||||||
}
|
}
|
||||||
|
|
||||||
let fmtstr = p.parse_expr()?;
|
let fmtstr = p.parse_expr()?;
|
||||||
|
let mut first = true;
|
||||||
let mut named = false;
|
let mut named = false;
|
||||||
|
|
||||||
while p.token != token::Eof {
|
while p.token != token::Eof {
|
||||||
if !p.eat(&token::Comma) {
|
if !p.eat(&token::Comma) {
|
||||||
|
if first {
|
||||||
|
// After `format!(""` we always expect *only* a comma...
|
||||||
let mut err = ecx.struct_span_err(p.token.span, "expected token: `,`");
|
let mut err = ecx.struct_span_err(p.token.span, "expected token: `,`");
|
||||||
err.span_label(p.token.span, "expected `,`");
|
err.span_label(p.token.span, "expected `,`");
|
||||||
p.maybe_annotate_with_ascription(&mut err, false);
|
p.maybe_annotate_with_ascription(&mut err, false);
|
||||||
return Err(err);
|
return Err(err);
|
||||||
|
} else {
|
||||||
|
// ...after that delegate to `expect` to also include the other expected tokens.
|
||||||
|
return Err(p.expect(&token::Comma).err().unwrap());
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
first = false;
|
||||||
if p.token == token::Eof {
|
if p.token == token::Eof {
|
||||||
break;
|
break;
|
||||||
} // accept trailing commas
|
} // accept trailing commas
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
fn main() {
|
fn main() {
|
||||||
format!(); //~ ERROR requires at least a format string argument
|
format!(); //~ ERROR requires at least a format string argument
|
||||||
format!("" 1); //~ ERROR expected token: `,`
|
format!("" 1); //~ ERROR expected token: `,`
|
||||||
format!("", 1 1); //~ ERROR expected token: `,`
|
format!("", 1 1); //~ ERROR expected one of
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -12,11 +12,11 @@ error: expected token: `,`
|
|||||||
LL | format!("" 1);
|
LL | format!("" 1);
|
||||||
| ^ expected `,`
|
| ^ expected `,`
|
||||||
|
|
||||||
error: expected token: `,`
|
error: expected one of `,`, `.`, `?`, or an operator, found `1`
|
||||||
--> $DIR/bad-format-args.rs:4:19
|
--> $DIR/bad-format-args.rs:4:19
|
||||||
|
|
|
|
||||||
LL | format!("", 1 1);
|
LL | format!("", 1 1);
|
||||||
| ^ expected `,`
|
| ^ expected one of `,`, `.`, `?`, or an operator here
|
||||||
|
|
||||||
error: aborting due to 3 previous errors
|
error: aborting due to 3 previous errors
|
||||||
|
|
||||||
|
|||||||
@@ -2,5 +2,5 @@ use std::collections::BTreeMap;
|
|||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
println!("{}", std::mem:size_of::<BTreeMap<u32, u32>>());
|
println!("{}", std::mem:size_of::<BTreeMap<u32, u32>>());
|
||||||
//~^ ERROR expected token: `,`
|
//~^ ERROR expected one of
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
error: expected token: `,`
|
error: expected one of `!`, `,`, or `::`, found `(`
|
||||||
--> $DIR/issue-54516.rs:4:58
|
--> $DIR/issue-54516.rs:4:58
|
||||||
|
|
|
|
||||||
LL | println!("{}", std::mem:size_of::<BTreeMap<u32, u32>>());
|
LL | println!("{}", std::mem:size_of::<BTreeMap<u32, u32>>());
|
||||||
| - ^ expected `,`
|
| - ^ expected one of `!`, `,`, or `::` here
|
||||||
| |
|
| |
|
||||||
| help: maybe write a path separator here: `::`
|
| help: maybe write a path separator here: `::`
|
||||||
|
|
|
|
||||||
|
|||||||
Reference in New Issue
Block a user