TypeParamList Owner

This commit is contained in:
Aleksey Kladov 2018-08-22 16:46:42 +03:00
parent 55896aedb1
commit 8e3bec11eb
5 changed files with 118 additions and 26 deletions

View file

@ -64,6 +64,7 @@ impl<'a> AstNode<'a> for ConstDef<'a> {
} }
impl<'a> ast::NameOwner<'a> for ConstDef<'a> {} impl<'a> ast::NameOwner<'a> for ConstDef<'a> {}
impl<'a> ast::TypeParamsOwner<'a> for ConstDef<'a> {}
impl<'a> ast::AttrsOwner<'a> for ConstDef<'a> {} impl<'a> ast::AttrsOwner<'a> for ConstDef<'a> {}
impl<'a> ConstDef<'a> {} impl<'a> ConstDef<'a> {}
@ -102,6 +103,7 @@ impl<'a> AstNode<'a> for EnumDef<'a> {
} }
impl<'a> ast::NameOwner<'a> for EnumDef<'a> {} impl<'a> ast::NameOwner<'a> for EnumDef<'a> {}
impl<'a> ast::TypeParamsOwner<'a> for EnumDef<'a> {}
impl<'a> ast::AttrsOwner<'a> for EnumDef<'a> {} impl<'a> ast::AttrsOwner<'a> for EnumDef<'a> {}
impl<'a> EnumDef<'a> {} impl<'a> EnumDef<'a> {}
@ -152,6 +154,7 @@ impl<'a> AstNode<'a> for FnDef<'a> {
} }
impl<'a> ast::NameOwner<'a> for FnDef<'a> {} impl<'a> ast::NameOwner<'a> for FnDef<'a> {}
impl<'a> ast::TypeParamsOwner<'a> for FnDef<'a> {}
impl<'a> ast::AttrsOwner<'a> for FnDef<'a> {} impl<'a> ast::AttrsOwner<'a> for FnDef<'a> {}
impl<'a> FnDef<'a> {} impl<'a> FnDef<'a> {}
@ -351,6 +354,7 @@ impl<'a> AstNode<'a> for NominalDef<'a> {
} }
impl<'a> ast::AttrsOwner<'a> for NominalDef<'a> {} impl<'a> ast::AttrsOwner<'a> for NominalDef<'a> {}
impl<'a> ast::TypeParamsOwner<'a> for NominalDef<'a> {}
impl<'a> NominalDef<'a> {} impl<'a> NominalDef<'a> {}
// ParenType // ParenType
@ -478,6 +482,7 @@ impl<'a> AstNode<'a> for StaticDef<'a> {
} }
impl<'a> ast::NameOwner<'a> for StaticDef<'a> {} impl<'a> ast::NameOwner<'a> for StaticDef<'a> {}
impl<'a> ast::TypeParamsOwner<'a> for StaticDef<'a> {}
impl<'a> ast::AttrsOwner<'a> for StaticDef<'a> {} impl<'a> ast::AttrsOwner<'a> for StaticDef<'a> {}
impl<'a> StaticDef<'a> {} impl<'a> StaticDef<'a> {}
@ -498,6 +503,7 @@ impl<'a> AstNode<'a> for StructDef<'a> {
} }
impl<'a> ast::NameOwner<'a> for StructDef<'a> {} impl<'a> ast::NameOwner<'a> for StructDef<'a> {}
impl<'a> ast::TypeParamsOwner<'a> for StructDef<'a> {}
impl<'a> ast::AttrsOwner<'a> for StructDef<'a> {} impl<'a> ast::AttrsOwner<'a> for StructDef<'a> {}
impl<'a> StructDef<'a> { impl<'a> StructDef<'a> {
pub fn fields(self) -> impl Iterator<Item = NamedField<'a>> + 'a { pub fn fields(self) -> impl Iterator<Item = NamedField<'a>> + 'a {
@ -580,9 +586,28 @@ impl<'a> AstNode<'a> for TypeDef<'a> {
} }
impl<'a> ast::NameOwner<'a> for TypeDef<'a> {} impl<'a> ast::NameOwner<'a> for TypeDef<'a> {}
impl<'a> ast::TypeParamsOwner<'a> for TypeDef<'a> {}
impl<'a> ast::AttrsOwner<'a> for TypeDef<'a> {} impl<'a> ast::AttrsOwner<'a> for TypeDef<'a> {}
impl<'a> TypeDef<'a> {} impl<'a> TypeDef<'a> {}
// TypeParamList
#[derive(Debug, Clone, Copy)]
pub struct TypeParamList<'a> {
syntax: SyntaxNodeRef<'a>,
}
impl<'a> AstNode<'a> for TypeParamList<'a> {
fn cast(syntax: SyntaxNodeRef<'a>) -> Option<Self> {
match syntax.kind() {
TYPE_PARAM_LIST => Some(TypeParamList { syntax }),
_ => None,
}
}
fn syntax(self) -> SyntaxNodeRef<'a> { self.syntax }
}
impl<'a> TypeParamList<'a> {}
// TypeRef // TypeRef
#[derive(Debug, Clone, Copy)] #[derive(Debug, Clone, Copy)]
pub enum TypeRef<'a> { pub enum TypeRef<'a> {
@ -641,21 +666,21 @@ impl<'a> AstNode<'a> for TypeRef<'a> {
impl<'a> TypeRef<'a> {} impl<'a> TypeRef<'a> {}
// Whitespace // WhereClause
#[derive(Debug, Clone, Copy)] #[derive(Debug, Clone, Copy)]
pub struct Whitespace<'a> { pub struct WhereClause<'a> {
syntax: SyntaxNodeRef<'a>, syntax: SyntaxNodeRef<'a>,
} }
impl<'a> AstNode<'a> for Whitespace<'a> { impl<'a> AstNode<'a> for WhereClause<'a> {
fn cast(syntax: SyntaxNodeRef<'a>) -> Option<Self> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option<Self> {
match syntax.kind() { match syntax.kind() {
WHITESPACE => Some(Whitespace { syntax }), WHERE_CLAUSE => Some(WhereClause { syntax }),
_ => None, _ => None,
} }
} }
fn syntax(self) -> SyntaxNodeRef<'a> { self.syntax } fn syntax(self) -> SyntaxNodeRef<'a> { self.syntax }
} }
impl<'a> Whitespace<'a> {} impl<'a> WhereClause<'a> {}

View file

@ -24,6 +24,22 @@ pub trait NameOwner<'a>: AstNode<'a> {
} }
} }
pub trait TypeParamsOwner<'a>: AstNode<'a> {
fn type_param_list(self) -> Option<TypeParamList<'a>> {
self.syntax()
.children()
.filter_map(TypeParamList::cast)
.next()
}
fn where_clause(self) -> Option<WhereClause<'a>> {
self.syntax()
.children()
.filter_map(WhereClause::cast)
.next()
}
}
pub trait AttrsOwner<'a>: AstNode<'a> { pub trait AttrsOwner<'a>: AstNode<'a> {
fn attrs(&self) -> Box<Iterator<Item=Attr<'a>> + 'a> { fn attrs(&self) -> Box<Iterator<Item=Attr<'a>> + 'a> {
let it = self.syntax().children() let it = self.syntax().children()

View file

@ -222,15 +222,27 @@ Grammar(
["modules", "Module"], ["modules", "Module"],
] ]
), ),
"FnDef": ( traits: ["NameOwner", "AttrsOwner"] ), "FnDef": ( traits: [
"NameOwner",
"TypeParamsOwner",
"AttrsOwner",
] ),
"StructDef": ( "StructDef": (
traits: ["NameOwner", "AttrsOwner"], traits: [
"NameOwner",
"TypeParamsOwner",
"AttrsOwner",
],
collections: [ collections: [
["fields", "NamedField"] ["fields", "NamedField"]
] ]
), ),
"NamedField": ( traits: ["NameOwner", "AttrsOwner"] ), "NamedField": ( traits: ["NameOwner", "AttrsOwner"] ),
"EnumDef": ( traits: ["NameOwner", "AttrsOwner"] ), "EnumDef": ( traits: [
"NameOwner",
"TypeParamsOwner",
"AttrsOwner",
] ),
"TraitDef": ( traits: ["NameOwner", "AttrsOwner"] ), "TraitDef": ( traits: ["NameOwner", "AttrsOwner"] ),
"Module": ( "Module": (
traits: ["NameOwner", "AttrsOwner"], traits: ["NameOwner", "AttrsOwner"],
@ -238,16 +250,23 @@ Grammar(
["modules", "Module"] ["modules", "Module"]
] ]
), ),
"ConstDef": ( traits: ["NameOwner", "AttrsOwner"] ), "ConstDef": ( traits: [
"StaticDef": ( traits: ["NameOwner", "AttrsOwner"] ), "NameOwner",
"TypeDef": ( traits: ["NameOwner", "AttrsOwner"] ), "TypeParamsOwner",
"AttrsOwner",
] ),
"StaticDef": ( traits: [
"NameOwner",
"TypeParamsOwner",
"AttrsOwner",
] ),
"TypeDef": ( traits: [
"NameOwner",
"TypeParamsOwner",
"AttrsOwner",
] ),
"ImplItem": (), "ImplItem": (),
"Name": (),
"NameRef": (),
"Attr": ( options: [ ["value", "TokenTree"] ] ),
"TokenTree": (),
"ParenType": (), "ParenType": (),
"TupleType": (), "TupleType": (),
"NeverType": (), "NeverType": (),
@ -280,7 +299,14 @@ Grammar(
"NominalDef": ( "NominalDef": (
enum: ["StructDef", "EnumDef"], enum: ["StructDef", "EnumDef"],
traits: [ "AttrsOwner" ], traits: [ "AttrsOwner", "TypeParamsOwner" ],
), ),
"Name": (),
"NameRef": (),
"Attr": ( options: [ ["value", "TokenTree"] ] ),
"TokenTree": (),
"TypeParamList": (),
"WhereClause": (),
}, },
) )

View file

@ -1,3 +1,3 @@
struct S { struct S<T: Copy> {
f: T,
} }

View file

@ -1,10 +1,35 @@
FILE@[0; 13) FILE@[0; 32)
STRUCT_DEF@[0; 13) STRUCT_DEF@[0; 31)
STRUCT_KW@[0; 6) STRUCT_KW@[0; 6)
WHITESPACE@[6; 7) WHITESPACE@[6; 7)
NAME@[7; 8) NAME@[7; 8)
IDENT@[7; 8) "S" IDENT@[7; 8) "S"
WHITESPACE@[8; 9) TYPE_PARAM_LIST@[8; 17)
L_CURLY@[9; 10) L_ANGLE@[8; 9)
WHITESPACE@[10; 12) TYPE_PARAM@[9; 16)
R_CURLY@[12; 13) NAME@[9; 10)
IDENT@[9; 10) "T"
COLON@[10; 11)
WHITESPACE@[11; 12)
PATH@[12; 16)
PATH_SEGMENT@[12; 16)
NAME_REF@[12; 16)
IDENT@[12; 16) "Copy"
R_ANGLE@[16; 17)
WHITESPACE@[17; 18)
L_CURLY@[18; 19)
WHITESPACE@[19; 24)
NAMED_FIELD@[24; 28)
NAME@[24; 25)
IDENT@[24; 25) "f"
COLON@[25; 26)
WHITESPACE@[26; 27)
PATH_TYPE@[27; 28)
PATH@[27; 28)
PATH_SEGMENT@[27; 28)
NAME_REF@[27; 28)
IDENT@[27; 28) "T"
COMMA@[28; 29)
WHITESPACE@[29; 30)
R_CURLY@[30; 31)
WHITESPACE@[31; 32)