rust-analyzer/crates/libsyntax2/src/ast/generated.rs

633 lines
17 KiB
Rust
Raw Normal View History

2018-08-09 14:43:39 +00:00
use std::sync::Arc;
use {
2018-08-11 09:28:59 +00:00
ast,
2018-08-09 14:43:39 +00:00
SyntaxNode, SyntaxRoot, TreeRoot, AstNode,
SyntaxKind::*,
};
2018-08-14 09:38:20 +00:00
// ArrayType
#[derive(Debug, Clone, Copy)]
pub struct ArrayType<R: TreeRoot = Arc<SyntaxRoot>> {
syntax: SyntaxNode<R>,
}
impl<R: TreeRoot> AstNode<R> for ArrayType<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
ARRAY_TYPE => Some(ArrayType { syntax }),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
impl<R: TreeRoot> ArrayType<R> {}
2018-08-16 09:51:40 +00:00
// Attr
#[derive(Debug, Clone, Copy)]
pub struct Attr<R: TreeRoot = Arc<SyntaxRoot>> {
syntax: SyntaxNode<R>,
}
impl<R: TreeRoot> AstNode<R> for Attr<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
ATTR => Some(Attr { syntax }),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
impl<R: TreeRoot> Attr<R> {
pub fn value(&self) -> Option<TokenTree<R>> {
self.syntax()
.children()
.filter_map(TokenTree::cast)
.next()
}
}
2018-08-13 15:36:16 +00:00
// ConstDef
2018-08-11 08:03:22 +00:00
#[derive(Debug, Clone, Copy)]
2018-08-13 15:36:16 +00:00
pub struct ConstDef<R: TreeRoot = Arc<SyntaxRoot>> {
2018-08-11 08:03:22 +00:00
syntax: SyntaxNode<R>,
}
2018-08-13 15:36:16 +00:00
impl<R: TreeRoot> AstNode<R> for ConstDef<R> {
2018-08-11 08:03:22 +00:00
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
2018-08-13 15:36:16 +00:00
CONST_DEF => Some(ConstDef { syntax }),
2018-08-11 08:03:22 +00:00
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
2018-08-13 15:36:16 +00:00
impl<R: TreeRoot> ast::NameOwner<R> for ConstDef<R> {}
2018-08-16 09:51:40 +00:00
impl<R: TreeRoot> ast::AttrsOwner<R> for ConstDef<R> {}
2018-08-13 15:36:16 +00:00
impl<R: TreeRoot> ConstDef<R> {}
2018-08-11 08:03:22 +00:00
2018-08-14 09:38:20 +00:00
// DynTraitType
#[derive(Debug, Clone, Copy)]
pub struct DynTraitType<R: TreeRoot = Arc<SyntaxRoot>> {
syntax: SyntaxNode<R>,
}
impl<R: TreeRoot> AstNode<R> for DynTraitType<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
DYN_TRAIT_TYPE => Some(DynTraitType { syntax }),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
impl<R: TreeRoot> DynTraitType<R> {}
2018-08-13 15:36:16 +00:00
// EnumDef
2018-08-11 07:56:40 +00:00
#[derive(Debug, Clone, Copy)]
2018-08-13 15:36:16 +00:00
pub struct EnumDef<R: TreeRoot = Arc<SyntaxRoot>> {
2018-08-11 07:56:40 +00:00
syntax: SyntaxNode<R>,
}
2018-08-13 15:36:16 +00:00
impl<R: TreeRoot> AstNode<R> for EnumDef<R> {
2018-08-11 07:56:40 +00:00
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
2018-08-13 15:36:16 +00:00
ENUM_DEF => Some(EnumDef { syntax }),
2018-08-11 07:56:40 +00:00
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
2018-08-13 15:36:16 +00:00
impl<R: TreeRoot> ast::NameOwner<R> for EnumDef<R> {}
2018-08-16 09:51:40 +00:00
impl<R: TreeRoot> ast::AttrsOwner<R> for EnumDef<R> {}
2018-08-13 15:36:16 +00:00
impl<R: TreeRoot> EnumDef<R> {}
2018-08-11 07:56:40 +00:00
2018-08-11 09:28:59 +00:00
// File
2018-08-10 12:07:43 +00:00
#[derive(Debug, Clone, Copy)]
2018-08-09 14:43:39 +00:00
pub struct File<R: TreeRoot = Arc<SyntaxRoot>> {
syntax: SyntaxNode<R>,
}
impl<R: TreeRoot> AstNode<R> for File<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
FILE => Some(File { syntax }),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
2018-08-11 06:55:32 +00:00
impl<R: TreeRoot> File<R> {
2018-08-13 15:36:16 +00:00
pub fn functions<'a>(&'a self) -> impl Iterator<Item = FnDef<R>> + 'a {
2018-08-11 06:55:32 +00:00
self.syntax()
.children()
2018-08-13 15:36:16 +00:00
.filter_map(FnDef::cast)
2018-08-11 06:55:32 +00:00
}
}
2018-08-13 15:36:16 +00:00
// FnDef
2018-08-10 12:07:43 +00:00
#[derive(Debug, Clone, Copy)]
2018-08-13 15:36:16 +00:00
pub struct FnDef<R: TreeRoot = Arc<SyntaxRoot>> {
2018-08-09 14:43:39 +00:00
syntax: SyntaxNode<R>,
}
2018-08-13 15:36:16 +00:00
impl<R: TreeRoot> AstNode<R> for FnDef<R> {
2018-08-09 14:43:39 +00:00
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
2018-08-13 15:36:16 +00:00
FN_DEF => Some(FnDef { syntax }),
2018-08-09 14:43:39 +00:00
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
2018-08-13 15:36:16 +00:00
impl<R: TreeRoot> ast::NameOwner<R> for FnDef<R> {}
2018-08-16 09:51:40 +00:00
impl<R: TreeRoot> ast::AttrsOwner<R> for FnDef<R> {}
2018-08-13 15:36:16 +00:00
impl<R: TreeRoot> FnDef<R> {}
2018-08-11 06:55:32 +00:00
2018-08-14 09:38:20 +00:00
// FnPointerType
#[derive(Debug, Clone, Copy)]
pub struct FnPointerType<R: TreeRoot = Arc<SyntaxRoot>> {
syntax: SyntaxNode<R>,
}
impl<R: TreeRoot> AstNode<R> for FnPointerType<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
FN_POINTER_TYPE => Some(FnPointerType { syntax }),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
impl<R: TreeRoot> FnPointerType<R> {}
// ForType
#[derive(Debug, Clone, Copy)]
pub struct ForType<R: TreeRoot = Arc<SyntaxRoot>> {
syntax: SyntaxNode<R>,
}
impl<R: TreeRoot> AstNode<R> for ForType<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
FOR_TYPE => Some(ForType { syntax }),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
impl<R: TreeRoot> ForType<R> {}
2018-08-14 08:20:09 +00:00
// ImplItem
#[derive(Debug, Clone, Copy)]
pub struct ImplItem<R: TreeRoot = Arc<SyntaxRoot>> {
syntax: SyntaxNode<R>,
}
impl<R: TreeRoot> AstNode<R> for ImplItem<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
IMPL_ITEM => Some(ImplItem { syntax }),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
impl<R: TreeRoot> ImplItem<R> {}
2018-08-14 09:38:20 +00:00
// ImplTraitType
#[derive(Debug, Clone, Copy)]
pub struct ImplTraitType<R: TreeRoot = Arc<SyntaxRoot>> {
syntax: SyntaxNode<R>,
}
impl<R: TreeRoot> AstNode<R> for ImplTraitType<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
IMPL_TRAIT_TYPE => Some(ImplTraitType { syntax }),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
impl<R: TreeRoot> ImplTraitType<R> {}
2018-08-11 09:28:59 +00:00
// Module
2018-08-11 08:03:22 +00:00
#[derive(Debug, Clone, Copy)]
pub struct Module<R: TreeRoot = Arc<SyntaxRoot>> {
syntax: SyntaxNode<R>,
}
impl<R: TreeRoot> AstNode<R> for Module<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
MODULE => Some(Module { syntax }),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
2018-08-11 09:28:59 +00:00
impl<R: TreeRoot> ast::NameOwner<R> for Module<R> {}
2018-08-16 09:51:40 +00:00
impl<R: TreeRoot> ast::AttrsOwner<R> for Module<R> {}
2018-08-11 09:28:59 +00:00
impl<R: TreeRoot> Module<R> {}
2018-08-11 08:03:22 +00:00
2018-08-11 09:28:59 +00:00
// Name
2018-08-10 12:07:43 +00:00
#[derive(Debug, Clone, Copy)]
2018-08-09 14:43:39 +00:00
pub struct Name<R: TreeRoot = Arc<SyntaxRoot>> {
syntax: SyntaxNode<R>,
}
impl<R: TreeRoot> AstNode<R> for Name<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
NAME => Some(Name { syntax }),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
2018-08-11 06:55:32 +00:00
impl<R: TreeRoot> Name<R> {}
2018-08-13 13:35:17 +00:00
// NameRef
#[derive(Debug, Clone, Copy)]
pub struct NameRef<R: TreeRoot = Arc<SyntaxRoot>> {
syntax: SyntaxNode<R>,
}
impl<R: TreeRoot> AstNode<R> for NameRef<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
NAME_REF => Some(NameRef { syntax }),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
impl<R: TreeRoot> NameRef<R> {}
2018-08-14 11:45:56 +00:00
// NamedField
#[derive(Debug, Clone, Copy)]
pub struct NamedField<R: TreeRoot = Arc<SyntaxRoot>> {
syntax: SyntaxNode<R>,
}
impl<R: TreeRoot> AstNode<R> for NamedField<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
NAMED_FIELD => Some(NamedField { syntax }),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
impl<R: TreeRoot> ast::NameOwner<R> for NamedField<R> {}
2018-08-16 09:51:40 +00:00
impl<R: TreeRoot> ast::AttrsOwner<R> for NamedField<R> {}
2018-08-14 11:45:56 +00:00
impl<R: TreeRoot> NamedField<R> {}
2018-08-14 09:38:20 +00:00
// NeverType
#[derive(Debug, Clone, Copy)]
pub struct NeverType<R: TreeRoot = Arc<SyntaxRoot>> {
syntax: SyntaxNode<R>,
}
impl<R: TreeRoot> AstNode<R> for NeverType<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
NEVER_TYPE => Some(NeverType { syntax }),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
impl<R: TreeRoot> NeverType<R> {}
2018-08-14 10:33:44 +00:00
// NominalDef
#[derive(Debug, Clone, Copy)]
pub enum NominalDef<R: TreeRoot = Arc<SyntaxRoot>> {
StructDef(StructDef<R>),
EnumDef(EnumDef<R>),
}
impl<R: TreeRoot> AstNode<R> for NominalDef<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
STRUCT_DEF => Some(NominalDef::StructDef(StructDef { syntax })),
ENUM_DEF => Some(NominalDef::EnumDef(EnumDef { syntax })),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> {
match self {
NominalDef::StructDef(inner) => inner.syntax(),
NominalDef::EnumDef(inner) => inner.syntax(),
}
}
}
2018-08-16 10:11:20 +00:00
impl<R: TreeRoot> ast::AttrsOwner<R> for NominalDef<R> {}
2018-08-14 10:33:44 +00:00
impl<R: TreeRoot> NominalDef<R> {}
2018-08-14 09:38:20 +00:00
// ParenType
#[derive(Debug, Clone, Copy)]
pub struct ParenType<R: TreeRoot = Arc<SyntaxRoot>> {
syntax: SyntaxNode<R>,
}
impl<R: TreeRoot> AstNode<R> for ParenType<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
PAREN_TYPE => Some(ParenType { syntax }),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
impl<R: TreeRoot> ParenType<R> {}
// PathType
#[derive(Debug, Clone, Copy)]
pub struct PathType<R: TreeRoot = Arc<SyntaxRoot>> {
syntax: SyntaxNode<R>,
}
impl<R: TreeRoot> AstNode<R> for PathType<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
PATH_TYPE => Some(PathType { syntax }),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
impl<R: TreeRoot> PathType<R> {}
// PlaceholderType
#[derive(Debug, Clone, Copy)]
pub struct PlaceholderType<R: TreeRoot = Arc<SyntaxRoot>> {
syntax: SyntaxNode<R>,
}
impl<R: TreeRoot> AstNode<R> for PlaceholderType<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
PLACEHOLDER_TYPE => Some(PlaceholderType { syntax }),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
impl<R: TreeRoot> PlaceholderType<R> {}
// PointerType
#[derive(Debug, Clone, Copy)]
pub struct PointerType<R: TreeRoot = Arc<SyntaxRoot>> {
syntax: SyntaxNode<R>,
}
impl<R: TreeRoot> AstNode<R> for PointerType<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
POINTER_TYPE => Some(PointerType { syntax }),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
impl<R: TreeRoot> PointerType<R> {}
// ReferenceType
#[derive(Debug, Clone, Copy)]
pub struct ReferenceType<R: TreeRoot = Arc<SyntaxRoot>> {
syntax: SyntaxNode<R>,
}
impl<R: TreeRoot> AstNode<R> for ReferenceType<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
REFERENCE_TYPE => Some(ReferenceType { syntax }),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
impl<R: TreeRoot> ReferenceType<R> {}
// SliceType
#[derive(Debug, Clone, Copy)]
pub struct SliceType<R: TreeRoot = Arc<SyntaxRoot>> {
syntax: SyntaxNode<R>,
}
impl<R: TreeRoot> AstNode<R> for SliceType<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
SLICE_TYPE => Some(SliceType { syntax }),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
impl<R: TreeRoot> SliceType<R> {}
2018-08-13 15:36:16 +00:00
// StaticDef
2018-08-11 08:03:22 +00:00
#[derive(Debug, Clone, Copy)]
2018-08-13 15:36:16 +00:00
pub struct StaticDef<R: TreeRoot = Arc<SyntaxRoot>> {
2018-08-11 08:03:22 +00:00
syntax: SyntaxNode<R>,
}
2018-08-13 15:36:16 +00:00
impl<R: TreeRoot> AstNode<R> for StaticDef<R> {
2018-08-11 08:03:22 +00:00
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
2018-08-13 15:36:16 +00:00
STATIC_DEF => Some(StaticDef { syntax }),
2018-08-11 08:03:22 +00:00
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
2018-08-13 15:36:16 +00:00
impl<R: TreeRoot> ast::NameOwner<R> for StaticDef<R> {}
2018-08-16 09:51:40 +00:00
impl<R: TreeRoot> ast::AttrsOwner<R> for StaticDef<R> {}
2018-08-13 15:36:16 +00:00
impl<R: TreeRoot> StaticDef<R> {}
2018-08-11 08:03:22 +00:00
2018-08-13 15:36:16 +00:00
// StructDef
2018-08-11 07:56:40 +00:00
#[derive(Debug, Clone, Copy)]
2018-08-13 15:36:16 +00:00
pub struct StructDef<R: TreeRoot = Arc<SyntaxRoot>> {
2018-08-11 07:56:40 +00:00
syntax: SyntaxNode<R>,
}
2018-08-13 15:36:16 +00:00
impl<R: TreeRoot> AstNode<R> for StructDef<R> {
2018-08-11 07:56:40 +00:00
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
2018-08-13 15:36:16 +00:00
STRUCT_DEF => Some(StructDef { syntax }),
2018-08-11 07:56:40 +00:00
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
2018-08-13 15:36:16 +00:00
impl<R: TreeRoot> ast::NameOwner<R> for StructDef<R> {}
2018-08-16 09:51:40 +00:00
impl<R: TreeRoot> ast::AttrsOwner<R> for StructDef<R> {}
2018-08-14 11:45:56 +00:00
impl<R: TreeRoot> StructDef<R> {
pub fn fields<'a>(&'a self) -> impl Iterator<Item = NamedField<R>> + 'a {
self.syntax()
.children()
.filter_map(NamedField::cast)
}
}
2018-08-11 07:56:40 +00:00
2018-08-16 09:51:40 +00:00
// TokenTree
#[derive(Debug, Clone, Copy)]
pub struct TokenTree<R: TreeRoot = Arc<SyntaxRoot>> {
syntax: SyntaxNode<R>,
}
impl<R: TreeRoot> AstNode<R> for TokenTree<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
TOKEN_TREE => Some(TokenTree { syntax }),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
impl<R: TreeRoot> TokenTree<R> {}
2018-08-13 15:36:16 +00:00
// TraitDef
2018-08-11 08:03:22 +00:00
#[derive(Debug, Clone, Copy)]
2018-08-13 15:36:16 +00:00
pub struct TraitDef<R: TreeRoot = Arc<SyntaxRoot>> {
2018-08-11 08:03:22 +00:00
syntax: SyntaxNode<R>,
}
2018-08-13 15:36:16 +00:00
impl<R: TreeRoot> AstNode<R> for TraitDef<R> {
2018-08-11 08:03:22 +00:00
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
2018-08-13 15:36:16 +00:00
TRAIT_DEF => Some(TraitDef { syntax }),
2018-08-11 08:03:22 +00:00
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
2018-08-13 15:36:16 +00:00
impl<R: TreeRoot> ast::NameOwner<R> for TraitDef<R> {}
2018-08-16 09:51:40 +00:00
impl<R: TreeRoot> ast::AttrsOwner<R> for TraitDef<R> {}
2018-08-13 15:36:16 +00:00
impl<R: TreeRoot> TraitDef<R> {}
2018-08-11 08:03:22 +00:00
2018-08-14 09:38:20 +00:00
// TupleType
#[derive(Debug, Clone, Copy)]
pub struct TupleType<R: TreeRoot = Arc<SyntaxRoot>> {
syntax: SyntaxNode<R>,
}
impl<R: TreeRoot> AstNode<R> for TupleType<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
TUPLE_TYPE => Some(TupleType { syntax }),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
impl<R: TreeRoot> TupleType<R> {}
2018-08-13 15:36:16 +00:00
// TypeDef
2018-08-11 13:20:37 +00:00
#[derive(Debug, Clone, Copy)]
2018-08-13 15:36:16 +00:00
pub struct TypeDef<R: TreeRoot = Arc<SyntaxRoot>> {
2018-08-11 13:20:37 +00:00
syntax: SyntaxNode<R>,
}
2018-08-13 15:36:16 +00:00
impl<R: TreeRoot> AstNode<R> for TypeDef<R> {
2018-08-11 13:20:37 +00:00
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
2018-08-13 15:36:16 +00:00
TYPE_DEF => Some(TypeDef { syntax }),
2018-08-11 13:20:37 +00:00
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
}
2018-08-13 15:36:16 +00:00
impl<R: TreeRoot> ast::NameOwner<R> for TypeDef<R> {}
2018-08-16 09:51:40 +00:00
impl<R: TreeRoot> ast::AttrsOwner<R> for TypeDef<R> {}
2018-08-13 15:36:16 +00:00
impl<R: TreeRoot> TypeDef<R> {}
2018-08-11 13:20:37 +00:00
2018-08-14 09:38:20 +00:00
// TypeRef
#[derive(Debug, Clone, Copy)]
pub enum TypeRef<R: TreeRoot = Arc<SyntaxRoot>> {
ParenType(ParenType<R>),
TupleType(TupleType<R>),
NeverType(NeverType<R>),
PathType(PathType<R>),
PointerType(PointerType<R>),
ArrayType(ArrayType<R>),
SliceType(SliceType<R>),
ReferenceType(ReferenceType<R>),
PlaceholderType(PlaceholderType<R>),
FnPointerType(FnPointerType<R>),
ForType(ForType<R>),
ImplTraitType(ImplTraitType<R>),
DynTraitType(DynTraitType<R>),
}
impl<R: TreeRoot> AstNode<R> for TypeRef<R> {
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
match syntax.kind() {
PAREN_TYPE => Some(TypeRef::ParenType(ParenType { syntax })),
TUPLE_TYPE => Some(TypeRef::TupleType(TupleType { syntax })),
NEVER_TYPE => Some(TypeRef::NeverType(NeverType { syntax })),
PATH_TYPE => Some(TypeRef::PathType(PathType { syntax })),
POINTER_TYPE => Some(TypeRef::PointerType(PointerType { syntax })),
ARRAY_TYPE => Some(TypeRef::ArrayType(ArrayType { syntax })),
SLICE_TYPE => Some(TypeRef::SliceType(SliceType { syntax })),
REFERENCE_TYPE => Some(TypeRef::ReferenceType(ReferenceType { syntax })),
PLACEHOLDER_TYPE => Some(TypeRef::PlaceholderType(PlaceholderType { syntax })),
FN_POINTER_TYPE => Some(TypeRef::FnPointerType(FnPointerType { syntax })),
FOR_TYPE => Some(TypeRef::ForType(ForType { syntax })),
IMPL_TRAIT_TYPE => Some(TypeRef::ImplTraitType(ImplTraitType { syntax })),
DYN_TRAIT_TYPE => Some(TypeRef::DynTraitType(DynTraitType { syntax })),
_ => None,
}
}
fn syntax(&self) -> &SyntaxNode<R> {
match self {
TypeRef::ParenType(inner) => inner.syntax(),
TypeRef::TupleType(inner) => inner.syntax(),
TypeRef::NeverType(inner) => inner.syntax(),
TypeRef::PathType(inner) => inner.syntax(),
TypeRef::PointerType(inner) => inner.syntax(),
TypeRef::ArrayType(inner) => inner.syntax(),
TypeRef::SliceType(inner) => inner.syntax(),
TypeRef::ReferenceType(inner) => inner.syntax(),
TypeRef::PlaceholderType(inner) => inner.syntax(),
TypeRef::FnPointerType(inner) => inner.syntax(),
TypeRef::ForType(inner) => inner.syntax(),
TypeRef::ImplTraitType(inner) => inner.syntax(),
TypeRef::DynTraitType(inner) => inner.syntax(),
}
}
}
impl<R: TreeRoot> TypeRef<R> {}