Separating parsing of for in predicates and types

This commit is contained in:
Matthew Jasper 2020-06-10 11:30:48 +01:00
parent 560b98bc50
commit 506e1ddbfa
12 changed files with 507 additions and 291 deletions

View file

@ -191,10 +191,30 @@ fn where_predicate(p: &mut Parser) {
} }
_ => { _ => {
// test where_pred_for // test where_pred_for
// fn test<F>() // fn for_trait<F>()
// where // where
// for<'a> F: Fn(&'a str) // for<'a> F: Fn(&'a str)
// { } // { }
// fn for_ref<F>()
// where
// for<'a> &'a F: Debug
// { }
// fn for_parens<F>()
// where
// for<'a> (&'a F): Fn(&'a str)
// { }
// fn for_slice<F>()
// where
// for<'a> [&'a F]: Eq
// { }
// fn for_qpath<T>(_t: &T)
// where
// for<'a> <&'a T as Baz>::Foo: Iterator
// { }
if p.at(T![for]) {
types::for_binder(p);
}
types::type_(p); types::type_(p);
if p.at(T![:]) { if p.at(T![:]) {

View file

@ -216,19 +216,20 @@ pub(super) fn for_binder(p: &mut Parser) {
// test for_type // test for_type
// type A = for<'a> fn() -> (); // type A = for<'a> fn() -> ();
// fn foo<T>(_t: &T) where for<'a> &'a T: Iterator {} // type B = for<'a> unsafe extern "C" fn(&'a ()) -> ();
// fn bar<T>(_t: &T) where for<'a> &'a mut T: Iterator {}
// fn baz<T>(_t: &T) where for<'a> <&'a T as Baz>::Foo: Iterator {}
pub(super) fn for_type(p: &mut Parser) { pub(super) fn for_type(p: &mut Parser) {
assert!(p.at(T![for])); assert!(p.at(T![for]));
let m = p.start(); let m = p.start();
for_binder(p); for_binder(p);
match p.current() { match p.current() {
T![fn] | T![unsafe] | T![extern] => fn_pointer_type(p), T![fn] | T![unsafe] | T![extern] => {}
T![&] => reference_type(p), // OK: legacy trait object format
_ if paths::is_path_start(p) => path_type_(p, false), _ if paths::is_use_path_start(p) => {}
_ => p.error("expected a path"), _ => {
p.error("expected a function pointer or path");
}
} }
type_no_bounds(p);
m.complete(p, FOR_TYPE); m.complete(p, FOR_TYPE);
} }

View file

@ -285,6 +285,8 @@ where
let pred = predicates.next().unwrap(); let pred = predicates.next().unwrap();
let mut bounds = pred.type_bound_list().unwrap().bounds(); let mut bounds = pred.type_bound_list().unwrap().bounds();
assert!(pred.for_token().is_none());
assert!(pred.type_param_list().is_none());
assert_eq!("T", pred.type_ref().unwrap().syntax().text().to_string()); assert_eq!("T", pred.type_ref().unwrap().syntax().text().to_string());
assert_bound("Clone", bounds.next()); assert_bound("Clone", bounds.next());
assert_bound("Copy", bounds.next()); assert_bound("Copy", bounds.next());
@ -322,6 +324,8 @@ where
let pred = predicates.next().unwrap(); let pred = predicates.next().unwrap();
let mut bounds = pred.type_bound_list().unwrap().bounds(); let mut bounds = pred.type_bound_list().unwrap().bounds();
assert_eq!("for<'a> F", pred.type_ref().unwrap().syntax().text().to_string()); assert!(pred.for_token().is_some());
assert_eq!("<'a>", pred.type_param_list().unwrap().syntax().text().to_string());
assert_eq!("F", pred.type_ref().unwrap().syntax().text().to_string());
assert_bound("Fn(&'a str)", bounds.next()); assert_bound("Fn(&'a str)", bounds.next());
} }

View file

@ -2052,6 +2052,8 @@ pub struct WherePred {
} }
impl ast::TypeBoundsOwner for WherePred {} impl ast::TypeBoundsOwner for WherePred {}
impl WherePred { impl WherePred {
pub fn for_token(&self) -> Option<SyntaxToken> { support::token(&self.syntax, T![for]) }
pub fn type_param_list(&self) -> Option<TypeParamList> { support::child(&self.syntax) }
pub fn lifetime_token(&self) -> Option<SyntaxToken> { pub fn lifetime_token(&self) -> Option<SyntaxToken> {
support::token(&self.syntax, T![lifetime]) support::token(&self.syntax, T![lifetime])
} }

View file

@ -12,17 +12,16 @@ SOURCE_FILE@0..30
WHERE_KW@13..18 "where" WHERE_KW@13..18 "where"
WHITESPACE@18..19 " " WHITESPACE@18..19 " "
WHERE_PRED@19..26 WHERE_PRED@19..26
FOR_TYPE@19..26 FOR_KW@19..22 "for"
FOR_KW@19..22 "for" TYPE_PARAM_LIST@22..26
TYPE_PARAM_LIST@22..26 L_ANGLE@22..23 "<"
L_ANGLE@22..23 "<" LIFETIME_PARAM@23..25
LIFETIME_PARAM@23..25 LIFETIME@23..25 "\'a"
LIFETIME@23..25 "\'a" R_ANGLE@25..26 ">"
R_ANGLE@25..26 ">"
WHITESPACE@26..27 "\n" WHITESPACE@26..27 "\n"
BLOCK_EXPR@27..29 BLOCK_EXPR@27..29
L_CURLY@27..28 "{" L_CURLY@27..28 "{"
R_CURLY@28..29 "}" R_CURLY@28..29 "}"
WHITESPACE@29..30 "\n" WHITESPACE@29..30 "\n"
error 26..26: expected a path error 26..26: expected type
error 26..26: expected colon error 26..26: expected colon

View file

@ -0,0 +1,88 @@
SOURCE_FILE@0..79
TYPE_ALIAS_DEF@0..25
TYPE_KW@0..4 "type"
WHITESPACE@4..5 " "
NAME@5..6
IDENT@5..6 "A"
WHITESPACE@6..7 " "
EQ@7..8 "="
WHITESPACE@8..9 " "
FOR_TYPE@9..24
FOR_KW@9..12 "for"
TYPE_PARAM_LIST@12..16
L_ANGLE@12..13 "<"
LIFETIME_PARAM@13..15
LIFETIME@13..15 "\'a"
R_ANGLE@15..16 ">"
WHITESPACE@16..17 " "
REFERENCE_TYPE@17..24
AMP@17..18 "&"
LIFETIME@18..20 "\'a"
WHITESPACE@20..21 " "
PATH_TYPE@21..24
PATH@21..24
PATH_SEGMENT@21..24
NAME_REF@21..24
IDENT@21..24 "u32"
SEMICOLON@24..25 ";"
WHITESPACE@25..26 "\n"
TYPE_ALIAS_DEF@26..54
TYPE_KW@26..30 "type"
WHITESPACE@30..31 " "
NAME@31..32
IDENT@31..32 "B"
WHITESPACE@32..33 " "
EQ@33..34 "="
WHITESPACE@34..35 " "
FOR_TYPE@35..53
FOR_KW@35..38 "for"
TYPE_PARAM_LIST@38..42
L_ANGLE@38..39 "<"
LIFETIME_PARAM@39..41
LIFETIME@39..41 "\'a"
R_ANGLE@41..42 ">"
WHITESPACE@42..43 " "
TUPLE_TYPE@43..53
L_PAREN@43..44 "("
REFERENCE_TYPE@44..51
AMP@44..45 "&"
LIFETIME@45..47 "\'a"
WHITESPACE@47..48 " "
PATH_TYPE@48..51
PATH@48..51
PATH_SEGMENT@48..51
NAME_REF@48..51
IDENT@48..51 "u32"
COMMA@51..52 ","
R_PAREN@52..53 ")"
SEMICOLON@53..54 ";"
WHITESPACE@54..55 "\n"
TYPE_ALIAS_DEF@55..78
TYPE_KW@55..59 "type"
WHITESPACE@59..60 " "
NAME@60..61
IDENT@60..61 "B"
WHITESPACE@61..62 " "
EQ@62..63 "="
WHITESPACE@63..64 " "
FOR_TYPE@64..77
FOR_KW@64..67 "for"
TYPE_PARAM_LIST@67..71
L_ANGLE@67..68 "<"
LIFETIME_PARAM@68..70
LIFETIME@68..70 "\'a"
R_ANGLE@70..71 ">"
WHITESPACE@71..72 " "
SLICE_TYPE@72..77
L_BRACK@72..73 "["
PATH_TYPE@73..76
PATH@73..76
PATH_SEGMENT@73..76
NAME_REF@73..76
IDENT@73..76 "u32"
R_BRACK@76..77 "]"
SEMICOLON@77..78 ";"
WHITESPACE@78..79 "\n"
error 16..16: expected a function pointer or path
error 42..42: expected a function pointer or path
error 71..71: expected a function pointer or path

View file

@ -0,0 +1,3 @@
type A = for<'a> &'a u32;
type B = for<'a> (&'a u32,);
type B = for<'a> [u32];

View file

@ -1,61 +1,310 @@
SOURCE_FILE@0..49 SOURCE_FILE@0..292
FN_DEF@0..48 FN_DEF@0..53
FN_KW@0..2 "fn" FN_KW@0..2 "fn"
WHITESPACE@2..3 " " WHITESPACE@2..3 " "
NAME@3..7 NAME@3..12
IDENT@3..7 "test" IDENT@3..12 "for_trait"
TYPE_PARAM_LIST@7..10 TYPE_PARAM_LIST@12..15
L_ANGLE@7..8 "<" L_ANGLE@12..13 "<"
TYPE_PARAM@8..9 TYPE_PARAM@13..14
NAME@8..9 NAME@13..14
IDENT@8..9 "F" IDENT@13..14 "F"
R_ANGLE@9..10 ">" R_ANGLE@14..15 ">"
PARAM_LIST@10..12 PARAM_LIST@15..17
L_PAREN@10..11 "(" L_PAREN@15..16 "("
R_PAREN@11..12 ")" R_PAREN@16..17 ")"
WHITESPACE@12..13 "\n" WHITESPACE@17..18 "\n"
WHERE_CLAUSE@13..44 WHERE_CLAUSE@18..49
WHERE_KW@13..18 "where" WHERE_KW@18..23 "where"
WHITESPACE@18..22 "\n " WHITESPACE@23..27 "\n "
WHERE_PRED@22..44 WHERE_PRED@27..49
FOR_TYPE@22..31 FOR_KW@27..30 "for"
FOR_KW@22..25 "for" TYPE_PARAM_LIST@30..34
TYPE_PARAM_LIST@25..29 L_ANGLE@30..31 "<"
L_ANGLE@25..26 "<" LIFETIME_PARAM@31..33
LIFETIME_PARAM@26..28 LIFETIME@31..33 "\'a"
LIFETIME@26..28 "\'a" R_ANGLE@33..34 ">"
R_ANGLE@28..29 ">" WHITESPACE@34..35 " "
WHITESPACE@29..30 " " PATH_TYPE@35..36
PATH_TYPE@30..31 PATH@35..36
PATH@30..31 PATH_SEGMENT@35..36
PATH_SEGMENT@30..31 NAME_REF@35..36
NAME_REF@30..31 IDENT@35..36 "F"
IDENT@30..31 "F" COLON@36..37 ":"
COLON@31..32 ":" WHITESPACE@37..38 " "
WHITESPACE@32..33 " " TYPE_BOUND_LIST@38..49
TYPE_BOUND_LIST@33..44 TYPE_BOUND@38..49
TYPE_BOUND@33..44 PATH_TYPE@38..49
PATH_TYPE@33..44 PATH@38..49
PATH@33..44 PATH_SEGMENT@38..49
PATH_SEGMENT@33..44 NAME_REF@38..40
NAME_REF@33..35 IDENT@38..40 "Fn"
IDENT@33..35 "Fn" PARAM_LIST@40..49
PARAM_LIST@35..44 L_PAREN@40..41 "("
L_PAREN@35..36 "(" PARAM@41..48
PARAM@36..43 REFERENCE_TYPE@41..48
REFERENCE_TYPE@36..43 AMP@41..42 "&"
AMP@36..37 "&" LIFETIME@42..44 "\'a"
LIFETIME@37..39 "\'a" WHITESPACE@44..45 " "
WHITESPACE@39..40 " " PATH_TYPE@45..48
PATH_TYPE@40..43 PATH@45..48
PATH@40..43 PATH_SEGMENT@45..48
PATH_SEGMENT@40..43 NAME_REF@45..48
NAME_REF@40..43 IDENT@45..48 "str"
IDENT@40..43 "str" R_PAREN@48..49 ")"
R_PAREN@43..44 ")" WHITESPACE@49..50 "\n"
WHITESPACE@44..45 "\n" BLOCK_EXPR@50..53
BLOCK_EXPR@45..48 L_CURLY@50..51 "{"
L_CURLY@45..46 "{" WHITESPACE@51..52 " "
WHITESPACE@46..47 " " R_CURLY@52..53 "}"
R_CURLY@47..48 "}" WHITESPACE@53..54 "\n"
WHITESPACE@48..49 "\n" FN_DEF@54..103
FN_KW@54..56 "fn"
WHITESPACE@56..57 " "
NAME@57..64
IDENT@57..64 "for_ref"
TYPE_PARAM_LIST@64..67
L_ANGLE@64..65 "<"
TYPE_PARAM@65..66
NAME@65..66
IDENT@65..66 "F"
R_ANGLE@66..67 ">"
PARAM_LIST@67..69
L_PAREN@67..68 "("
R_PAREN@68..69 ")"
WHITESPACE@69..70 "\n"
WHERE_CLAUSE@70..99
WHERE_KW@70..75 "where"
WHITESPACE@75..79 "\n "
WHERE_PRED@79..99
FOR_KW@79..82 "for"
TYPE_PARAM_LIST@82..86
L_ANGLE@82..83 "<"
LIFETIME_PARAM@83..85
LIFETIME@83..85 "\'a"
R_ANGLE@85..86 ">"
WHITESPACE@86..87 " "
REFERENCE_TYPE@87..92
AMP@87..88 "&"
LIFETIME@88..90 "\'a"
WHITESPACE@90..91 " "
PATH_TYPE@91..92
PATH@91..92
PATH_SEGMENT@91..92
NAME_REF@91..92
IDENT@91..92 "F"
COLON@92..93 ":"
WHITESPACE@93..94 " "
TYPE_BOUND_LIST@94..99
TYPE_BOUND@94..99
PATH_TYPE@94..99
PATH@94..99
PATH_SEGMENT@94..99
NAME_REF@94..99
IDENT@94..99 "Debug"
WHITESPACE@99..100 "\n"
BLOCK_EXPR@100..103
L_CURLY@100..101 "{"
WHITESPACE@101..102 " "
R_CURLY@102..103 "}"
WHITESPACE@103..104 "\n"
FN_DEF@104..164
FN_KW@104..106 "fn"
WHITESPACE@106..107 " "
NAME@107..117
IDENT@107..117 "for_parens"
TYPE_PARAM_LIST@117..120
L_ANGLE@117..118 "<"
TYPE_PARAM@118..119
NAME@118..119
IDENT@118..119 "F"
R_ANGLE@119..120 ">"
PARAM_LIST@120..122
L_PAREN@120..121 "("
R_PAREN@121..122 ")"
WHITESPACE@122..123 "\n"
WHERE_CLAUSE@123..160
WHERE_KW@123..128 "where"
WHITESPACE@128..132 "\n "
WHERE_PRED@132..160
FOR_KW@132..135 "for"
TYPE_PARAM_LIST@135..139
L_ANGLE@135..136 "<"
LIFETIME_PARAM@136..138
LIFETIME@136..138 "\'a"
R_ANGLE@138..139 ">"
WHITESPACE@139..140 " "
PAREN_TYPE@140..147
L_PAREN@140..141 "("
REFERENCE_TYPE@141..146
AMP@141..142 "&"
LIFETIME@142..144 "\'a"
WHITESPACE@144..145 " "
PATH_TYPE@145..146
PATH@145..146
PATH_SEGMENT@145..146
NAME_REF@145..146
IDENT@145..146 "F"
R_PAREN@146..147 ")"
COLON@147..148 ":"
WHITESPACE@148..149 " "
TYPE_BOUND_LIST@149..160
TYPE_BOUND@149..160
PATH_TYPE@149..160
PATH@149..160
PATH_SEGMENT@149..160
NAME_REF@149..151
IDENT@149..151 "Fn"
PARAM_LIST@151..160
L_PAREN@151..152 "("
PARAM@152..159
REFERENCE_TYPE@152..159
AMP@152..153 "&"
LIFETIME@153..155 "\'a"
WHITESPACE@155..156 " "
PATH_TYPE@156..159
PATH@156..159
PATH_SEGMENT@156..159
NAME_REF@156..159
IDENT@156..159 "str"
R_PAREN@159..160 ")"
WHITESPACE@160..161 "\n"
BLOCK_EXPR@161..164
L_CURLY@161..162 "{"
WHITESPACE@162..163 " "
R_CURLY@163..164 "}"
WHITESPACE@164..165 "\n"
FN_DEF@165..215
FN_KW@165..167 "fn"
WHITESPACE@167..168 " "
NAME@168..177
IDENT@168..177 "for_slice"
TYPE_PARAM_LIST@177..180
L_ANGLE@177..178 "<"
TYPE_PARAM@178..179
NAME@178..179
IDENT@178..179 "F"
R_ANGLE@179..180 ">"
PARAM_LIST@180..182
L_PAREN@180..181 "("
R_PAREN@181..182 ")"
WHITESPACE@182..183 "\n"
WHERE_CLAUSE@183..211
WHERE_KW@183..188 "where"
WHITESPACE@188..192 "\n "
WHERE_PRED@192..211
FOR_KW@192..195 "for"
TYPE_PARAM_LIST@195..199
L_ANGLE@195..196 "<"
LIFETIME_PARAM@196..198
LIFETIME@196..198 "\'a"
R_ANGLE@198..199 ">"
WHITESPACE@199..200 " "
SLICE_TYPE@200..207
L_BRACK@200..201 "["
REFERENCE_TYPE@201..206
AMP@201..202 "&"
LIFETIME@202..204 "\'a"
WHITESPACE@204..205 " "
PATH_TYPE@205..206
PATH@205..206
PATH_SEGMENT@205..206
NAME_REF@205..206
IDENT@205..206 "F"
R_BRACK@206..207 "]"
COLON@207..208 ":"
WHITESPACE@208..209 " "
TYPE_BOUND_LIST@209..211
TYPE_BOUND@209..211
PATH_TYPE@209..211
PATH@209..211
PATH_SEGMENT@209..211
NAME_REF@209..211
IDENT@209..211 "Eq"
WHITESPACE@211..212 "\n"
BLOCK_EXPR@212..215
L_CURLY@212..213 "{"
WHITESPACE@213..214 " "
R_CURLY@214..215 "}"
WHITESPACE@215..216 "\n"
FN_DEF@216..291
FN_KW@216..218 "fn"
WHITESPACE@218..219 " "
NAME@219..228
IDENT@219..228 "for_qpath"
TYPE_PARAM_LIST@228..231
L_ANGLE@228..229 "<"
TYPE_PARAM@229..230
NAME@229..230
IDENT@229..230 "T"
R_ANGLE@230..231 ">"
PARAM_LIST@231..239
L_PAREN@231..232 "("
PARAM@232..238
BIND_PAT@232..234
NAME@232..234
IDENT@232..234 "_t"
COLON@234..235 ":"
WHITESPACE@235..236 " "
REFERENCE_TYPE@236..238
AMP@236..237 "&"
PATH_TYPE@237..238
PATH@237..238
PATH_SEGMENT@237..238
NAME_REF@237..238
IDENT@237..238 "T"
R_PAREN@238..239 ")"
WHITESPACE@239..240 "\n"
WHERE_CLAUSE@240..287
WHERE_KW@240..245 "where"
WHITESPACE@245..250 "\n "
WHERE_PRED@250..287
FOR_KW@250..253 "for"
TYPE_PARAM_LIST@253..257
L_ANGLE@253..254 "<"
LIFETIME_PARAM@254..256
LIFETIME@254..256 "\'a"
R_ANGLE@256..257 ">"
WHITESPACE@257..258 " "
PATH_TYPE@258..277
PATH@258..277
PATH@258..272
PATH_SEGMENT@258..272
L_ANGLE@258..259 "<"
REFERENCE_TYPE@259..264
AMP@259..260 "&"
LIFETIME@260..262 "\'a"
WHITESPACE@262..263 " "
PATH_TYPE@263..264
PATH@263..264
PATH_SEGMENT@263..264
NAME_REF@263..264
IDENT@263..264 "T"
WHITESPACE@264..265 " "
AS_KW@265..267 "as"
WHITESPACE@267..268 " "
PATH_TYPE@268..271
PATH@268..271
PATH_SEGMENT@268..271
NAME_REF@268..271
IDENT@268..271 "Baz"
R_ANGLE@271..272 ">"
COLON2@272..274 "::"
PATH_SEGMENT@274..277
NAME_REF@274..277
IDENT@274..277 "Foo"
COLON@277..278 ":"
WHITESPACE@278..279 " "
TYPE_BOUND_LIST@279..287
TYPE_BOUND@279..287
PATH_TYPE@279..287
PATH@279..287
PATH_SEGMENT@279..287
NAME_REF@279..287
IDENT@279..287 "Iterator"
WHITESPACE@287..288 "\n"
BLOCK_EXPR@288..291
L_CURLY@288..289 "{"
WHITESPACE@289..290 " "
R_CURLY@290..291 "}"
WHITESPACE@291..292 "\n"

View file

@ -1,4 +1,20 @@
fn test<F>() fn for_trait<F>()
where where
for<'a> F: Fn(&'a str) for<'a> F: Fn(&'a str)
{ } { }
fn for_ref<F>()
where
for<'a> &'a F: Debug
{ }
fn for_parens<F>()
where
for<'a> (&'a F): Fn(&'a str)
{ }
fn for_slice<F>()
where
for<'a> [&'a F]: Eq
{ }
fn for_qpath<T>(_t: &T)
where
for<'a> <&'a T as Baz>::Foo: Iterator
{ }

View file

@ -1,4 +1,4 @@
SOURCE_FILE@0..200 SOURCE_FILE@0..82
TYPE_ALIAS_DEF@0..28 TYPE_ALIAS_DEF@0..28
TYPE_KW@0..4 "type" TYPE_KW@0..4 "type"
WHITESPACE@4..5 " " WHITESPACE@4..5 " "
@ -29,212 +29,48 @@ SOURCE_FILE@0..200
R_PAREN@26..27 ")" R_PAREN@26..27 ")"
SEMICOLON@27..28 ";" SEMICOLON@27..28 ";"
WHITESPACE@28..29 "\n" WHITESPACE@28..29 "\n"
FN_DEF@29..79 TYPE_ALIAS_DEF@29..81
FN_KW@29..31 "fn" TYPE_KW@29..33 "type"
WHITESPACE@31..32 " " WHITESPACE@33..34 " "
NAME@32..35 NAME@34..35
IDENT@32..35 "foo" IDENT@34..35 "B"
TYPE_PARAM_LIST@35..38 WHITESPACE@35..36 " "
L_ANGLE@35..36 "<" EQ@36..37 "="
TYPE_PARAM@36..37 WHITESPACE@37..38 " "
NAME@36..37 FOR_TYPE@38..80
IDENT@36..37 "T" FOR_KW@38..41 "for"
R_ANGLE@37..38 ">" TYPE_PARAM_LIST@41..45
PARAM_LIST@38..46 L_ANGLE@41..42 "<"
L_PAREN@38..39 "(" LIFETIME_PARAM@42..44
PARAM@39..45 LIFETIME@42..44 "\'a"
BIND_PAT@39..41 R_ANGLE@44..45 ">"
NAME@39..41 WHITESPACE@45..46 " "
IDENT@39..41 "_t" FN_POINTER_TYPE@46..80
COLON@41..42 ":" UNSAFE_KW@46..52 "unsafe"
WHITESPACE@42..43 " " WHITESPACE@52..53 " "
REFERENCE_TYPE@43..45 ABI@53..63
AMP@43..44 "&" EXTERN_KW@53..59 "extern"
PATH_TYPE@44..45 WHITESPACE@59..60 " "
PATH@44..45 STRING@60..63 "\"C\""
PATH_SEGMENT@44..45 WHITESPACE@63..64 " "
NAME_REF@44..45 FN_KW@64..66 "fn"
IDENT@44..45 "T" PARAM_LIST@66..74
R_PAREN@45..46 ")" L_PAREN@66..67 "("
WHITESPACE@46..47 " " PARAM@67..73
WHERE_CLAUSE@47..76 REFERENCE_TYPE@67..73
WHERE_KW@47..52 "where" AMP@67..68 "&"
WHITESPACE@52..53 " " LIFETIME@68..70 "\'a"
WHERE_PRED@53..76 WHITESPACE@70..71 " "
FOR_TYPE@53..66 TUPLE_TYPE@71..73
FOR_KW@53..56 "for" L_PAREN@71..72 "("
TYPE_PARAM_LIST@56..60 R_PAREN@72..73 ")"
L_ANGLE@56..57 "<" R_PAREN@73..74 ")"
LIFETIME_PARAM@57..59 WHITESPACE@74..75 " "
LIFETIME@57..59 "\'a" RET_TYPE@75..80
R_ANGLE@59..60 ">" THIN_ARROW@75..77 "->"
WHITESPACE@60..61 " " WHITESPACE@77..78 " "
REFERENCE_TYPE@61..66 TUPLE_TYPE@78..80
AMP@61..62 "&" L_PAREN@78..79 "("
LIFETIME@62..64 "\'a" R_PAREN@79..80 ")"
WHITESPACE@64..65 " " SEMICOLON@80..81 ";"
PATH_TYPE@65..66 WHITESPACE@81..82 "\n"
PATH@65..66
PATH_SEGMENT@65..66
NAME_REF@65..66
IDENT@65..66 "T"
COLON@66..67 ":"
WHITESPACE@67..68 " "
TYPE_BOUND_LIST@68..76
TYPE_BOUND@68..76
PATH_TYPE@68..76
PATH@68..76
PATH_SEGMENT@68..76
NAME_REF@68..76
IDENT@68..76 "Iterator"
WHITESPACE@76..77 " "
BLOCK_EXPR@77..79
L_CURLY@77..78 "{"
R_CURLY@78..79 "}"
WHITESPACE@79..80 "\n"
FN_DEF@80..134
FN_KW@80..82 "fn"
WHITESPACE@82..83 " "
NAME@83..86
IDENT@83..86 "bar"
TYPE_PARAM_LIST@86..89
L_ANGLE@86..87 "<"
TYPE_PARAM@87..88
NAME@87..88
IDENT@87..88 "T"
R_ANGLE@88..89 ">"
PARAM_LIST@89..97
L_PAREN@89..90 "("
PARAM@90..96
BIND_PAT@90..92
NAME@90..92
IDENT@90..92 "_t"
COLON@92..93 ":"
WHITESPACE@93..94 " "
REFERENCE_TYPE@94..96
AMP@94..95 "&"
PATH_TYPE@95..96
PATH@95..96
PATH_SEGMENT@95..96
NAME_REF@95..96
IDENT@95..96 "T"
R_PAREN@96..97 ")"
WHITESPACE@97..98 " "
WHERE_CLAUSE@98..131
WHERE_KW@98..103 "where"
WHITESPACE@103..104 " "
WHERE_PRED@104..131
FOR_TYPE@104..121
FOR_KW@104..107 "for"
TYPE_PARAM_LIST@107..111
L_ANGLE@107..108 "<"
LIFETIME_PARAM@108..110
LIFETIME@108..110 "\'a"
R_ANGLE@110..111 ">"
WHITESPACE@111..112 " "
REFERENCE_TYPE@112..121
AMP@112..113 "&"
LIFETIME@113..115 "\'a"
WHITESPACE@115..116 " "
MUT_KW@116..119 "mut"
WHITESPACE@119..120 " "
PATH_TYPE@120..121
PATH@120..121
PATH_SEGMENT@120..121
NAME_REF@120..121
IDENT@120..121 "T"
COLON@121..122 ":"
WHITESPACE@122..123 " "
TYPE_BOUND_LIST@123..131
TYPE_BOUND@123..131
PATH_TYPE@123..131
PATH@123..131
PATH_SEGMENT@123..131
NAME_REF@123..131
IDENT@123..131 "Iterator"
WHITESPACE@131..132 " "
BLOCK_EXPR@132..134
L_CURLY@132..133 "{"
R_CURLY@133..134 "}"
WHITESPACE@134..135 "\n"
FN_DEF@135..199
FN_KW@135..137 "fn"
WHITESPACE@137..138 " "
NAME@138..141
IDENT@138..141 "baz"
TYPE_PARAM_LIST@141..144
L_ANGLE@141..142 "<"
TYPE_PARAM@142..143
NAME@142..143
IDENT@142..143 "T"
R_ANGLE@143..144 ">"
PARAM_LIST@144..152
L_PAREN@144..145 "("
PARAM@145..151
BIND_PAT@145..147
NAME@145..147
IDENT@145..147 "_t"
COLON@147..148 ":"
WHITESPACE@148..149 " "
REFERENCE_TYPE@149..151
AMP@149..150 "&"
PATH_TYPE@150..151
PATH@150..151
PATH_SEGMENT@150..151
NAME_REF@150..151
IDENT@150..151 "T"
R_PAREN@151..152 ")"
WHITESPACE@152..153 " "
WHERE_CLAUSE@153..196
WHERE_KW@153..158 "where"
WHITESPACE@158..159 " "
WHERE_PRED@159..196
FOR_TYPE@159..186
FOR_KW@159..162 "for"
TYPE_PARAM_LIST@162..166
L_ANGLE@162..163 "<"
LIFETIME_PARAM@163..165
LIFETIME@163..165 "\'a"
R_ANGLE@165..166 ">"
WHITESPACE@166..167 " "
PATH_TYPE@167..186
PATH@167..186
PATH@167..181
PATH_SEGMENT@167..181
L_ANGLE@167..168 "<"
REFERENCE_TYPE@168..173
AMP@168..169 "&"
LIFETIME@169..171 "\'a"
WHITESPACE@171..172 " "
PATH_TYPE@172..173
PATH@172..173
PATH_SEGMENT@172..173
NAME_REF@172..173
IDENT@172..173 "T"
WHITESPACE@173..174 " "
AS_KW@174..176 "as"
WHITESPACE@176..177 " "
PATH_TYPE@177..180
PATH@177..180
PATH_SEGMENT@177..180
NAME_REF@177..180
IDENT@177..180 "Baz"
R_ANGLE@180..181 ">"
COLON2@181..183 "::"
PATH_SEGMENT@183..186
NAME_REF@183..186
IDENT@183..186 "Foo"
COLON@186..187 ":"
WHITESPACE@187..188 " "
TYPE_BOUND_LIST@188..196
TYPE_BOUND@188..196
PATH_TYPE@188..196
PATH@188..196
PATH_SEGMENT@188..196
NAME_REF@188..196
IDENT@188..196 "Iterator"
WHITESPACE@196..197 " "
BLOCK_EXPR@197..199
L_CURLY@197..198 "{"
R_CURLY@198..199 "}"
WHITESPACE@199..200 "\n"

View file

@ -1,4 +1,2 @@
type A = for<'a> fn() -> (); type A = for<'a> fn() -> ();
fn foo<T>(_t: &T) where for<'a> &'a T: Iterator {} type B = for<'a> unsafe extern "C" fn(&'a ()) -> ();
fn bar<T>(_t: &T) where for<'a> &'a mut T: Iterator {}
fn baz<T>(_t: &T) where for<'a> <&'a T as Baz>::Foo: Iterator {}

View file

@ -1707,7 +1707,7 @@ pub(crate) const AST_SRC: AstSrc = AstSrc {
/// ``` /// ```
/// ///
/// [Reference](https://doc.rust-lang.org/reference/items/generics.html#where-clauses) /// [Reference](https://doc.rust-lang.org/reference/items/generics.html#where-clauses)
struct WherePred: TypeBoundsOwner { T![lifetime], TypeRef } struct WherePred: TypeBoundsOwner { T![for], TypeParamList, T![lifetime], TypeRef }
/// Where clause. /// Where clause.
/// ///