mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-26 11:55:04 +00:00
Separating parsing of for
in predicates and types
This commit is contained in:
parent
560b98bc50
commit
506e1ddbfa
12 changed files with 507 additions and 291 deletions
|
@ -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![:]) {
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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());
|
||||||
}
|
}
|
||||||
|
|
|
@ -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])
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
|
@ -0,0 +1,3 @@
|
||||||
|
type A = for<'a> &'a u32;
|
||||||
|
type B = for<'a> (&'a u32,);
|
||||||
|
type B = for<'a> [u32];
|
|
@ -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"
|
||||||
|
|
|
@ -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
|
||||||
|
{ }
|
||||||
|
|
|
@ -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"
|
|
||||||
|
|
|
@ -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 {}
|
|
||||||
|
|
|
@ -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.
|
||||||
///
|
///
|
||||||
|
|
Loading…
Reference in a new issue