G: type_parameter_list

This commit is contained in:
Aleksey Kladov 2018-01-30 22:53:19 +03:00
parent 94caa9d3a2
commit 197a2e6fef
10 changed files with 248 additions and 7 deletions

View file

@ -17,6 +17,11 @@ Grammar(
"super", "super",
"in", "in",
"where", "where",
"for",
"loop",
"while",
"if",
"match"
], ],
tokens: [ tokens: [
"ERROR", "ERROR",

View file

@ -103,8 +103,32 @@ fn type_param_list(p: &mut Parser) {
assert!(p.at(IDENT)); assert!(p.at(IDENT));
let m = p.start(); let m = p.start();
p.bump(); p.bump();
if p.eat(COLON) {
loop {
let has_paren = p.eat(L_PAREN);
p.eat(QUESTION);
if p.at(FOR_KW) {
//TODO
}
if p.at(LIFETIME) {
p.bump();
} else if paths::is_path_start(p) {
paths::type_path(p);
} else {
break;
}
if has_paren {
p.expect(R_PAREN);
}
if !p.eat(PLUS) {
break;
}
}
}
if p.at(EQ) {
types::type_ref(p)
}
m.complete(p, TYPE_PARAM); m.complete(p, TYPE_PARAM);
//TODO: bounds
} }
} }

View file

@ -1,10 +1,18 @@
use super::*; use super::*;
pub(crate) fn is_path_start(p: &Parser) -> bool { pub(super) fn is_path_start(p: &Parser) -> bool {
AnyOf(&[IDENT, SELF_KW, SUPER_KW, COLONCOLON]).is_ahead(p) AnyOf(&[IDENT, SELF_KW, SUPER_KW, COLONCOLON]).is_ahead(p)
} }
pub(crate) fn use_path(p: &mut Parser) { pub(super) fn use_path(p: &mut Parser) {
path(p)
}
pub(super) fn type_path(p: &mut Parser) {
path(p)
}
fn path(p: &mut Parser) {
if !is_path_start(p) { if !is_path_start(p) {
return; return;
} }
@ -24,6 +32,7 @@ pub(crate) fn use_path(p: &mut Parser) {
} }
} }
fn path_segment(p: &mut Parser, first: bool) { fn path_segment(p: &mut Parser, first: bool) {
let segment = p.start(); let segment = p.start();
if first { if first {

View file

@ -23,6 +23,11 @@ pub enum SyntaxKind {
SUPER_KW, SUPER_KW,
IN_KW, IN_KW,
WHERE_KW, WHERE_KW,
FOR_KW,
LOOP_KW,
WHILE_KW,
IF_KW,
MATCH_KW,
ERROR, ERROR,
IDENT, IDENT,
UNDERSCORE, UNDERSCORE,
@ -125,6 +130,11 @@ impl SyntaxKind {
SUPER_KW => &SyntaxInfo { name: "SUPER_KW" }, SUPER_KW => &SyntaxInfo { name: "SUPER_KW" },
IN_KW => &SyntaxInfo { name: "IN_KW" }, IN_KW => &SyntaxInfo { name: "IN_KW" },
WHERE_KW => &SyntaxInfo { name: "WHERE_KW" }, WHERE_KW => &SyntaxInfo { name: "WHERE_KW" },
FOR_KW => &SyntaxInfo { name: "FOR_KW" },
LOOP_KW => &SyntaxInfo { name: "LOOP_KW" },
WHILE_KW => &SyntaxInfo { name: "WHILE_KW" },
IF_KW => &SyntaxInfo { name: "IF_KW" },
MATCH_KW => &SyntaxInfo { name: "MATCH_KW" },
ERROR => &SyntaxInfo { name: "ERROR" }, ERROR => &SyntaxInfo { name: "ERROR" },
IDENT => &SyntaxInfo { name: "IDENT" }, IDENT => &SyntaxInfo { name: "IDENT" },
UNDERSCORE => &SyntaxInfo { name: "UNDERSCORE" }, UNDERSCORE => &SyntaxInfo { name: "UNDERSCORE" },
@ -223,6 +233,11 @@ pub(crate) fn ident_to_keyword(ident: &str) -> Option<SyntaxKind> {
"super" => Some(SUPER_KW), "super" => Some(SUPER_KW),
"in" => Some(IN_KW), "in" => Some(IN_KW),
"where" => Some(WHERE_KW), "where" => Some(WHERE_KW),
"for" => Some(FOR_KW),
"loop" => Some(LOOP_KW),
"while" => Some(WHILE_KW),
"if" => Some(IF_KW),
"match" => Some(MATCH_KW),
_ => None, _ => None,
} }
} }

View file

@ -1 +1 @@
fn use struct trait enum impl true false as extern crate mod pub self super in where fn use struct trait enum impl true false as extern crate mod pub self super in where for loop while if match

View file

@ -31,4 +31,14 @@ WHITESPACE 1 " "
IN_KW 2 "in" IN_KW 2 "in"
WHITESPACE 1 " " WHITESPACE 1 " "
WHERE_KW 5 "where" WHERE_KW 5 "where"
WHITESPACE 1 " "
FOR_KW 3 "for"
WHITESPACE 1 " "
LOOP_KW 4 "loop"
WHITESPACE 1 " "
WHILE_KW 5 "while"
WHITESPACE 1 " "
IF_KW 2 "if"
WHITESPACE 1 " "
MATCH_KW 5 "match"
WHITESPACE 1 "\n" WHITESPACE 1 "\n"

View file

@ -1,11 +1,11 @@
FILE@[0; 21) FILE@[0; 21)
ERROR@[0; 3) ERROR@[0; 3)
err: `expected item` err: `expected item`
IDENT@[0; 2) "if" IF_KW@[0; 2)
WHITESPACE@[2; 3) WHITESPACE@[2; 3)
ERROR@[3; 10) ERROR@[3; 10)
err: `expected item` err: `expected item`
IDENT@[3; 8) "match" MATCH_KW@[3; 8)
WHITESPACE@[8; 10) WHITESPACE@[8; 10)
STRUCT_ITEM@[10; 21) STRUCT_ITEM@[10; 21)
STRUCT_KW@[10; 16) STRUCT_KW@[10; 16)

View file

@ -24,7 +24,7 @@ FILE@[0; 95)
err: `expected item` err: `expected item`
L_CURLY@[20; 21) L_CURLY@[20; 21)
WHITESPACE@[21; 26) WHITESPACE@[21; 26)
IDENT@[26; 28) "if" IF_KW@[26; 28)
WHITESPACE@[28; 29) WHITESPACE@[28; 29)
TRUE_KW@[29; 33) TRUE_KW@[29; 33)
WHITESPACE@[33; 34) WHITESPACE@[33; 34)

View file

@ -0,0 +1,9 @@
struct A<T>;
struct B<T:>;
struct C<T: 'a>;
struct D<T: 'a + >;
struct E<T: 'a + 'd >;
struct F<T: 'a + 'd + Clone>;
struct G<T: Clone + Copy>;
struct H<T: ::Foo + self::Bar + 'a>;
struct I<T:, U:,>;

View file

@ -0,0 +1,169 @@
FILE@[0; 200)
STRUCT_ITEM@[0; 13)
STRUCT_KW@[0; 6)
WHITESPACE@[6; 7)
IDENT@[7; 8) "A"
TYPE_PARAM_LIST@[8; 11)
L_ANGLE@[8; 9)
TYPE_PARAM@[9; 10)
IDENT@[9; 10) "T"
R_ANGLE@[10; 11)
SEMI@[11; 12)
WHITESPACE@[12; 13)
STRUCT_ITEM@[13; 27)
STRUCT_KW@[13; 19)
WHITESPACE@[19; 20)
IDENT@[20; 21) "B"
TYPE_PARAM_LIST@[21; 25)
L_ANGLE@[21; 22)
TYPE_PARAM@[22; 24)
IDENT@[22; 23) "T"
COLON@[23; 24)
R_ANGLE@[24; 25)
SEMI@[25; 26)
WHITESPACE@[26; 27)
STRUCT_ITEM@[27; 44)
STRUCT_KW@[27; 33)
WHITESPACE@[33; 34)
IDENT@[34; 35) "C"
TYPE_PARAM_LIST@[35; 42)
L_ANGLE@[35; 36)
TYPE_PARAM@[36; 41)
IDENT@[36; 37) "T"
COLON@[37; 38)
WHITESPACE@[38; 39)
LIFETIME@[39; 41) "'a"
R_ANGLE@[41; 42)
SEMI@[42; 43)
WHITESPACE@[43; 44)
STRUCT_ITEM@[44; 64)
STRUCT_KW@[44; 50)
WHITESPACE@[50; 51)
IDENT@[51; 52) "D"
TYPE_PARAM_LIST@[52; 62)
L_ANGLE@[52; 53)
TYPE_PARAM@[53; 61)
IDENT@[53; 54) "T"
COLON@[54; 55)
WHITESPACE@[55; 56)
LIFETIME@[56; 58) "'a"
WHITESPACE@[58; 59)
PLUS@[59; 60)
WHITESPACE@[60; 61)
R_ANGLE@[61; 62)
SEMI@[62; 63)
WHITESPACE@[63; 64)
STRUCT_ITEM@[64; 87)
STRUCT_KW@[64; 70)
WHITESPACE@[70; 71)
IDENT@[71; 72) "E"
TYPE_PARAM_LIST@[72; 85)
L_ANGLE@[72; 73)
TYPE_PARAM@[73; 84)
IDENT@[73; 74) "T"
COLON@[74; 75)
WHITESPACE@[75; 76)
LIFETIME@[76; 78) "'a"
WHITESPACE@[78; 79)
PLUS@[79; 80)
WHITESPACE@[80; 81)
LIFETIME@[81; 83) "'d"
WHITESPACE@[83; 84)
R_ANGLE@[84; 85)
SEMI@[85; 86)
WHITESPACE@[86; 87)
STRUCT_ITEM@[87; 117)
STRUCT_KW@[87; 93)
WHITESPACE@[93; 94)
IDENT@[94; 95) "F"
TYPE_PARAM_LIST@[95; 115)
L_ANGLE@[95; 96)
TYPE_PARAM@[96; 114)
IDENT@[96; 97) "T"
COLON@[97; 98)
WHITESPACE@[98; 99)
LIFETIME@[99; 101) "'a"
WHITESPACE@[101; 102)
PLUS@[102; 103)
WHITESPACE@[103; 104)
LIFETIME@[104; 106) "'d"
WHITESPACE@[106; 107)
PLUS@[107; 108)
PATH@[108; 114)
PATH_SEGMENT@[108; 114)
WHITESPACE@[108; 109)
IDENT@[109; 114) "Clone"
R_ANGLE@[114; 115)
SEMI@[115; 116)
WHITESPACE@[116; 117)
STRUCT_ITEM@[117; 144)
STRUCT_KW@[117; 123)
WHITESPACE@[123; 124)
IDENT@[124; 125) "G"
TYPE_PARAM_LIST@[125; 142)
L_ANGLE@[125; 126)
TYPE_PARAM@[126; 141)
IDENT@[126; 127) "T"
COLON@[127; 128)
PATH@[128; 135)
PATH_SEGMENT@[128; 135)
WHITESPACE@[128; 129)
IDENT@[129; 134) "Clone"
WHITESPACE@[134; 135)
PLUS@[135; 136)
PATH@[136; 141)
PATH_SEGMENT@[136; 141)
WHITESPACE@[136; 137)
IDENT@[137; 141) "Copy"
R_ANGLE@[141; 142)
SEMI@[142; 143)
WHITESPACE@[143; 144)
STRUCT_ITEM@[144; 181)
STRUCT_KW@[144; 150)
WHITESPACE@[150; 151)
IDENT@[151; 152) "H"
TYPE_PARAM_LIST@[152; 179)
L_ANGLE@[152; 153)
TYPE_PARAM@[153; 178)
IDENT@[153; 154) "T"
COLON@[154; 155)
PATH@[155; 162)
PATH_SEGMENT@[155; 162)
WHITESPACE@[155; 156)
COLONCOLON@[156; 158)
IDENT@[158; 161) "Foo"
WHITESPACE@[161; 162)
PLUS@[162; 163)
PATH@[163; 174)
PATH@[163; 168)
PATH_SEGMENT@[163; 168)
WHITESPACE@[163; 164)
SELF_KW@[164; 168)
COLONCOLON@[168; 170)
PATH_SEGMENT@[170; 174)
IDENT@[170; 173) "Bar"
WHITESPACE@[173; 174)
PLUS@[174; 175)
WHITESPACE@[175; 176)
LIFETIME@[176; 178) "'a"
R_ANGLE@[178; 179)
SEMI@[179; 180)
WHITESPACE@[180; 181)
STRUCT_ITEM@[181; 200)
STRUCT_KW@[181; 187)
WHITESPACE@[187; 188)
IDENT@[188; 189) "I"
TYPE_PARAM_LIST@[189; 198)
L_ANGLE@[189; 190)
TYPE_PARAM@[190; 192)
IDENT@[190; 191) "T"
COLON@[191; 192)
COMMA@[192; 193)
TYPE_PARAM@[193; 196)
WHITESPACE@[193; 194)
IDENT@[194; 195) "U"
COLON@[195; 196)
COMMA@[196; 197)
R_ANGLE@[197; 198)
SEMI@[198; 199)
WHITESPACE@[199; 200)