mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-13 13:48:50 +00:00
G: type_parameter_list
This commit is contained in:
parent
94caa9d3a2
commit
197a2e6fef
10 changed files with 248 additions and 7 deletions
|
@ -17,6 +17,11 @@ Grammar(
|
||||||
"super",
|
"super",
|
||||||
"in",
|
"in",
|
||||||
"where",
|
"where",
|
||||||
|
"for",
|
||||||
|
"loop",
|
||||||
|
"while",
|
||||||
|
"if",
|
||||||
|
"match"
|
||||||
],
|
],
|
||||||
tokens: [
|
tokens: [
|
||||||
"ERROR",
|
"ERROR",
|
||||||
|
|
|
@ -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
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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 {
|
||||||
|
|
|
@ -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,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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"
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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)
|
||||||
|
|
9
tests/data/parser/ok/0020_type_param_bounds.rs
Normal file
9
tests/data/parser/ok/0020_type_param_bounds.rs
Normal 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:,>;
|
169
tests/data/parser/ok/0020_type_param_bounds.txt
Normal file
169
tests/data/parser/ok/0020_type_param_bounds.txt
Normal 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)
|
Loading…
Reference in a new issue