mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-12 21:28:51 +00:00
better self-types
This commit is contained in:
parent
cf7d4a2a24
commit
dc40f1298a
8 changed files with 67 additions and 45 deletions
|
@ -208,7 +208,7 @@ fn extern_crate_item(p: &mut Parser) {
|
|||
assert!(p.at(CRATE_KW));
|
||||
p.bump();
|
||||
name(p);
|
||||
alias(p);
|
||||
opt_alias(p);
|
||||
p.expect(SEMI);
|
||||
}
|
||||
|
||||
|
|
|
@ -26,7 +26,7 @@ fn use_tree(p: &mut Parser) {
|
|||
paths::use_path(p);
|
||||
match p.current() {
|
||||
AS_KW => {
|
||||
alias(p);
|
||||
opt_alias(p);
|
||||
}
|
||||
COLONCOLON => {
|
||||
p.bump();
|
||||
|
|
|
@ -92,14 +92,14 @@ fn opt_visibility(p: &mut Parser) {
|
|||
_ => (),
|
||||
}
|
||||
}
|
||||
fn alias(p: &mut Parser) -> bool {
|
||||
|
||||
fn opt_alias(p: &mut Parser) {
|
||||
if p.at(AS_KW) {
|
||||
let alias = p.start();
|
||||
let m = p.start();
|
||||
p.bump();
|
||||
name(p);
|
||||
alias.complete(p, ALIAS);
|
||||
m.complete(p, ALIAS);
|
||||
}
|
||||
true //FIXME: return false if three are errors
|
||||
}
|
||||
|
||||
fn abi(p: &mut Parser) {
|
||||
|
|
|
@ -92,16 +92,18 @@ fn value_parameter(p: &mut Parser, flavor: Flavor) {
|
|||
// fn b(&self,) {}
|
||||
// fn c(&'a self,) {}
|
||||
// fn d(&'a mut self, x: i32) {}
|
||||
// fn e(mut self) {}
|
||||
// }
|
||||
fn self_param(p: &mut Parser) {
|
||||
let m;
|
||||
if p.at(SELF_KW) {
|
||||
if p.at(SELF_KW) || p.at(MUT_KW) && p.nth(1) == SELF_KW {
|
||||
m = p.start();
|
||||
p.bump();
|
||||
p.eat(MUT_KW);
|
||||
p.eat(SELF_KW);
|
||||
// test arb_self_types
|
||||
// impl S {
|
||||
// fn a(self: &Self) {}
|
||||
// fn b(self: Box<Self>) {}
|
||||
// fn b(mut self: Box<Self>) {}
|
||||
// }
|
||||
if p.at(COLON) {
|
||||
types::ascription(p);
|
||||
|
|
|
@ -3,4 +3,5 @@ impl S {
|
|||
fn b(&self,) {}
|
||||
fn c(&'a self,) {}
|
||||
fn d(&'a mut self, x: i32) {}
|
||||
fn e(mut self) {}
|
||||
}
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
FILE@[0; 106)
|
||||
IMPL_ITEM@[0; 105)
|
||||
FILE@[0; 128)
|
||||
IMPL_ITEM@[0; 127)
|
||||
IMPL_KW@[0; 4)
|
||||
WHITESPACE@[4; 5)
|
||||
PATH_TYPE@[5; 6)
|
||||
|
@ -93,6 +93,23 @@ FILE@[0; 106)
|
|||
BLOCK_EXPR@[101; 103)
|
||||
L_CURLY@[101; 102)
|
||||
R_CURLY@[102; 103)
|
||||
WHITESPACE@[103; 104)
|
||||
R_CURLY@[104; 105)
|
||||
WHITESPACE@[105; 106)
|
||||
WHITESPACE@[103; 108)
|
||||
FN_DEF@[108; 125)
|
||||
FN_KW@[108; 110)
|
||||
WHITESPACE@[110; 111)
|
||||
NAME@[111; 112)
|
||||
IDENT@[111; 112) "e"
|
||||
PARAM_LIST@[112; 122)
|
||||
L_PAREN@[112; 113)
|
||||
SELF_PARAM@[113; 121)
|
||||
MUT_KW@[113; 116)
|
||||
WHITESPACE@[116; 117)
|
||||
SELF_KW@[117; 121)
|
||||
R_PAREN@[121; 122)
|
||||
WHITESPACE@[122; 123)
|
||||
BLOCK_EXPR@[123; 125)
|
||||
L_CURLY@[123; 124)
|
||||
R_CURLY@[124; 125)
|
||||
WHITESPACE@[125; 126)
|
||||
R_CURLY@[126; 127)
|
||||
WHITESPACE@[127; 128)
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
impl S {
|
||||
fn a(self: &Self) {}
|
||||
fn b(self: Box<Self>) {}
|
||||
fn b(mut self: Box<Self>) {}
|
||||
}
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
FILE@[0; 65)
|
||||
IMPL_ITEM@[0; 64)
|
||||
FILE@[0; 69)
|
||||
IMPL_ITEM@[0; 68)
|
||||
IMPL_KW@[0; 4)
|
||||
WHITESPACE@[4; 5)
|
||||
PATH_TYPE@[5; 6)
|
||||
|
@ -34,36 +34,38 @@ FILE@[0; 65)
|
|||
L_CURLY@[31; 32)
|
||||
R_CURLY@[32; 33)
|
||||
WHITESPACE@[33; 38)
|
||||
FN_DEF@[38; 62)
|
||||
FN_DEF@[38; 66)
|
||||
FN_KW@[38; 40)
|
||||
WHITESPACE@[40; 41)
|
||||
NAME@[41; 42)
|
||||
IDENT@[41; 42) "b"
|
||||
PARAM_LIST@[42; 59)
|
||||
PARAM_LIST@[42; 63)
|
||||
L_PAREN@[42; 43)
|
||||
SELF_PARAM@[43; 58)
|
||||
SELF_KW@[43; 47)
|
||||
COLON@[47; 48)
|
||||
WHITESPACE@[48; 49)
|
||||
PATH_TYPE@[49; 58)
|
||||
PATH@[49; 58)
|
||||
PATH_SEGMENT@[49; 58)
|
||||
NAME_REF@[49; 52)
|
||||
IDENT@[49; 52) "Box"
|
||||
TYPE_ARG_LIST@[52; 58)
|
||||
L_ANGLE@[52; 53)
|
||||
TYPE_ARG@[53; 57)
|
||||
PATH_TYPE@[53; 57)
|
||||
PATH@[53; 57)
|
||||
PATH_SEGMENT@[53; 57)
|
||||
NAME_REF@[53; 57)
|
||||
IDENT@[53; 57) "Self"
|
||||
R_ANGLE@[57; 58)
|
||||
R_PAREN@[58; 59)
|
||||
WHITESPACE@[59; 60)
|
||||
BLOCK_EXPR@[60; 62)
|
||||
L_CURLY@[60; 61)
|
||||
R_CURLY@[61; 62)
|
||||
WHITESPACE@[62; 63)
|
||||
R_CURLY@[63; 64)
|
||||
WHITESPACE@[64; 65)
|
||||
SELF_PARAM@[43; 62)
|
||||
MUT_KW@[43; 46)
|
||||
WHITESPACE@[46; 47)
|
||||
SELF_KW@[47; 51)
|
||||
COLON@[51; 52)
|
||||
WHITESPACE@[52; 53)
|
||||
PATH_TYPE@[53; 62)
|
||||
PATH@[53; 62)
|
||||
PATH_SEGMENT@[53; 62)
|
||||
NAME_REF@[53; 56)
|
||||
IDENT@[53; 56) "Box"
|
||||
TYPE_ARG_LIST@[56; 62)
|
||||
L_ANGLE@[56; 57)
|
||||
TYPE_ARG@[57; 61)
|
||||
PATH_TYPE@[57; 61)
|
||||
PATH@[57; 61)
|
||||
PATH_SEGMENT@[57; 61)
|
||||
NAME_REF@[57; 61)
|
||||
IDENT@[57; 61) "Self"
|
||||
R_ANGLE@[61; 62)
|
||||
R_PAREN@[62; 63)
|
||||
WHITESPACE@[63; 64)
|
||||
BLOCK_EXPR@[64; 66)
|
||||
L_CURLY@[64; 65)
|
||||
R_CURLY@[65; 66)
|
||||
WHITESPACE@[66; 67)
|
||||
R_CURLY@[67; 68)
|
||||
WHITESPACE@[68; 69)
|
||||
|
|
Loading…
Reference in a new issue