G: special-case C++ semicolon

This commit is contained in:
Aleksey Kladov 2018-01-08 21:57:19 +03:00
parent ea186fe2c0
commit b61617f752
4 changed files with 58 additions and 9 deletions

View file

@ -1,17 +1,40 @@
use super::*; use super::*;
pub(super) fn item_first(p: &Parser) -> bool { pub(super) fn mod_items(p: &mut Parser) {
many(p, |p| {
skip_to_first(
p, item_first, mod_item,
"expected item",
)
});
}
fn item_first(p: &Parser) -> bool {
match p.current() { match p.current() {
STRUCT_KW | FN_KW => true, STRUCT_KW | FN_KW => true,
_ => false, _ => false,
} }
} }
pub(super) fn item(p: &mut Parser) { fn mod_item(p: &mut Parser) {
if item(p) {
if p.current() == SEMI {
node(p, ERROR, |p| {
p.error()
.message("expected item, found `;`\n\
consider removing this semicolon")
.emit();
p.bump();
})
}
}
}
fn item(p: &mut Parser) -> bool {
attributes::outer_attributes(p); attributes::outer_attributes(p);
visibility(p); visibility(p);
node_if(p, STRUCT_KW, STRUCT_ITEM, struct_item) node_if(p, STRUCT_KW, STRUCT_ITEM, struct_item)
|| node_if(p, FN_KW, FN_ITEM, fn_item); || node_if(p, FN_KW, FN_ITEM, fn_item)
} }
fn struct_item(p: &mut Parser) { fn struct_item(p: &mut Parser) {

View file

@ -11,12 +11,7 @@ pub(crate) fn file(p: &mut Parser) {
node(p, FILE, |p| { node(p, FILE, |p| {
p.optional(SHEBANG); p.optional(SHEBANG);
attributes::inner_attributes(p); attributes::inner_attributes(p);
many(p, |p| { items::mod_items(p);
skip_to_first(
p, items::item_first, items::item,
"expected item",
)
});
}) })
} }

View file

@ -0,0 +1,4 @@
struct S {
a: i32,
b: String,
};

View file

@ -0,0 +1,27 @@
FILE@[0; 40)
STRUCT_ITEM@[0; 39)
STRUCT_KW@[0; 6)
WHITESPACE@[6; 7)
IDENT@[7; 8)
WHITESPACE@[8; 9)
L_CURLY@[9; 10)
STRUCT_FIELD@[10; 21)
WHITESPACE@[10; 15)
IDENT@[15; 16)
COLON@[16; 17)
WHITESPACE@[17; 18)
IDENT@[18; 21)
COMMA@[21; 22)
STRUCT_FIELD@[22; 36)
WHITESPACE@[22; 27)
IDENT@[27; 28)
COLON@[28; 29)
WHITESPACE@[29; 30)
IDENT@[30; 36)
COMMA@[36; 37)
WHITESPACE@[37; 38)
R_CURLY@[38; 39)
ERROR@[39; 40)
err: `expected item, found `;`
consider removing this semicolon`
SEMI@[39; 40)