2018-10-16 18:09:22 +00:00
|
|
|
// This file is automatically generated based on the file `./generated.rs.tera` when `cargo gen-syntax` is run
|
2018-10-04 20:43:58 +00:00
|
|
|
// Do not edit manually
|
|
|
|
|
2018-11-06 19:06:58 +00:00
|
|
|
//! This module contains auto-generated Rust AST. Like `SyntaxNode`s, AST nodes
|
|
|
|
//! are generic over ownership: `X<'a>` things are `Copy` references, `XNode`
|
|
|
|
//! are Arc-based. You can switch between the two variants using `.owned` and
|
|
|
|
//! `.borrowed` functions. Most of the code works with borowed mode, and only
|
|
|
|
//! this mode has all AST accessors.
|
|
|
|
|
2018-10-15 21:44:23 +00:00
|
|
|
#![cfg_attr(rustfmt, rustfmt_skip)]
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
use rowan::TransparentNewType;
|
2018-11-06 19:47:38 +00:00
|
|
|
|
2018-10-15 16:55:32 +00:00
|
|
|
use crate::{
|
2019-01-07 13:16:02 +00:00
|
|
|
SyntaxNode, SyntaxKind::*,
|
2019-01-11 16:59:06 +00:00
|
|
|
yellow::{RaTypes, TreeArc},
|
2019-01-07 13:16:02 +00:00
|
|
|
ast::{self, AstNode},
|
2018-08-09 14:43:39 +00:00
|
|
|
};
|
|
|
|
|
2018-08-28 20:59:57 +00:00
|
|
|
// ArgList
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct ArgList {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-28 20:59:57 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for ArgList {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for ArgList {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-28 20:59:57 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
ARG_LIST => Some(ArgList::from_repr(syntax.into_repr())),
|
2018-08-28 20:59:57 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<ArgList> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-28 20:59:57 +00:00
|
|
|
}
|
|
|
|
|
2018-10-31 07:27:53 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ArgList {
|
|
|
|
pub fn args(&self) -> impl Iterator<Item = &Expr> {
|
2018-11-06 18:52:00 +00:00
|
|
|
super::children(self)
|
2018-10-31 07:27:53 +00:00
|
|
|
}
|
|
|
|
}
|
2018-11-01 10:41:04 +00:00
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
// ArrayExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct ArrayExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for ArrayExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for ArrayExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
ARRAY_EXPR => Some(ArrayExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<ArrayExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-13 13:46:10 +00:00
|
|
|
impl ArrayExpr {
|
|
|
|
pub fn exprs(&self) -> impl Iterator<Item = &Expr> {
|
|
|
|
super::children(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// ArrayType
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct ArrayType {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-14 09:38:20 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for ArrayType {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for ArrayType {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-14 09:38:20 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
ARRAY_TYPE => Some(ArrayType::from_repr(syntax.into_repr())),
|
2018-08-14 09:38:20 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<ArrayType> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ArrayType {
|
|
|
|
pub fn type_ref(&self) -> Option<&TypeRef> {
|
2018-12-25 20:14:13 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn expr(&self) -> Option<&Expr> {
|
2018-12-25 20:14:13 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// Attr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct Attr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for Attr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for Attr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-16 09:51:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
ATTR => Some(Attr::from_repr(syntax.into_repr())),
|
2018-08-16 09:51:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<Attr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-16 09:51:40 +00:00
|
|
|
}
|
|
|
|
|
2018-10-31 07:27:53 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl Attr {
|
|
|
|
pub fn value(&self) -> Option<&TokenTree> {
|
2018-11-06 18:52:00 +00:00
|
|
|
super::child_opt(self)
|
2018-10-31 07:27:53 +00:00
|
|
|
}
|
|
|
|
}
|
2018-11-01 10:41:04 +00:00
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
// BinExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct BinExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-25 10:42:40 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for BinExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for BinExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
BIN_EXPR => Some(BinExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<BinExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl BinExpr {}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// BindPat
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct BindPat {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for BindPat {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for BindPat {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-26 09:09:28 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
BIND_PAT => Some(BindPat::from_repr(syntax.into_repr())),
|
2018-08-26 09:09:28 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<BindPat> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ast::NameOwner for BindPat {}
|
2019-01-17 12:08:18 +00:00
|
|
|
impl BindPat {
|
|
|
|
pub fn pat(&self) -> Option<&Pat> {
|
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-08-26 09:09:28 +00:00
|
|
|
|
2018-08-25 10:42:40 +00:00
|
|
|
// Block
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct Block {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-25 10:42:40 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for Block {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for Block {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
BLOCK => Some(Block::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<Block> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl Block {
|
|
|
|
pub fn statements(&self) -> impl Iterator<Item = &Stmt> {
|
2018-08-26 09:09:28 +00:00
|
|
|
super::children(self)
|
|
|
|
}
|
2018-10-10 15:26:01 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn expr(&self) -> Option<&Expr> {
|
2018-08-27 07:12:28 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2018-08-26 09:09:28 +00:00
|
|
|
}
|
2018-08-25 10:42:40 +00:00
|
|
|
|
|
|
|
// BlockExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct BlockExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for BlockExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for BlockExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
BLOCK_EXPR => Some(BlockExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<BlockExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-27 09:22:09 +00:00
|
|
|
}
|
2018-08-25 10:42:40 +00:00
|
|
|
|
2018-10-31 07:27:53 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl BlockExpr {
|
|
|
|
pub fn block(&self) -> Option<&Block> {
|
2018-11-06 18:52:00 +00:00
|
|
|
super::child_opt(self)
|
2018-10-31 07:27:53 +00:00
|
|
|
}
|
|
|
|
}
|
2018-11-01 10:41:04 +00:00
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
// BreakExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct BreakExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-25 10:42:40 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for BreakExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for BreakExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
BREAK_EXPR => Some(BreakExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<BreakExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl BreakExpr {
|
|
|
|
pub fn expr(&self) -> Option<&Expr> {
|
2019-01-05 15:32:07 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2018-11-11 19:27:00 +00:00
|
|
|
// Byte
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct Byte {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-11 19:27:00 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for Byte {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-11 19:27:00 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for Byte {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-11-11 19:27:00 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
BYTE => Some(Byte::from_repr(syntax.into_repr())),
|
2018-11-11 19:27:00 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<Byte> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-11 19:27:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-08 09:23:10 +00:00
|
|
|
impl ast::AstToken for Byte {}
|
2019-01-07 13:16:02 +00:00
|
|
|
impl Byte {}
|
2018-11-11 19:27:00 +00:00
|
|
|
|
2018-11-11 19:41:43 +00:00
|
|
|
// ByteString
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct ByteString {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-11 19:41:43 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for ByteString {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-11 19:41:43 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for ByteString {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-11-11 19:41:43 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
BYTE_STRING => Some(ByteString::from_repr(syntax.into_repr())),
|
2018-11-11 19:41:43 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<ByteString> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-11 19:41:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-08 09:23:10 +00:00
|
|
|
impl ast::AstToken for ByteString {}
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ByteString {}
|
2018-11-11 19:41:43 +00:00
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
// CallExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct CallExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for CallExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for CallExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
CALL_EXPR => Some(CallExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<CallExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ast::ArgListOwner for CallExpr {}
|
|
|
|
impl CallExpr {
|
|
|
|
pub fn expr(&self) -> Option<&Expr> {
|
2018-08-28 20:59:57 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-08-25 10:42:40 +00:00
|
|
|
|
|
|
|
// CastExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct CastExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-25 10:42:40 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for CastExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for CastExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
CAST_EXPR => Some(CastExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<CastExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-04 14:06:38 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl CastExpr {
|
|
|
|
pub fn expr(&self) -> Option<&Expr> {
|
2018-12-20 20:56:28 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn type_ref(&self) -> Option<&TypeRef> {
|
2018-12-20 20:56:28 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// Char
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct Char {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for Char {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for Char {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-11-04 14:06:38 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
CHAR => Some(Char::from_repr(syntax.into_repr())),
|
2018-11-04 14:06:38 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<Char> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-08 09:23:10 +00:00
|
|
|
impl ast::AstToken for Char {}
|
2019-01-07 13:16:02 +00:00
|
|
|
impl Char {}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// Comment
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct Comment {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-10-11 14:25:35 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for Comment {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for Comment {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-10-11 14:25:35 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
COMMENT => Some(Comment::from_repr(syntax.into_repr())),
|
2018-10-11 14:25:35 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<Comment> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-08 09:23:10 +00:00
|
|
|
impl ast::AstToken for Comment {}
|
2019-01-07 13:16:02 +00:00
|
|
|
impl Comment {}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// Condition
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct Condition {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for Condition {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for Condition {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-27 09:22:09 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
CONDITION => Some(Condition::from_repr(syntax.into_repr())),
|
2018-08-27 09:22:09 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<Condition> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl Condition {
|
|
|
|
pub fn pat(&self) -> Option<&Pat> {
|
2018-08-27 09:22:09 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2018-10-10 15:26:01 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn expr(&self) -> Option<&Expr> {
|
2018-08-27 09:22:09 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-13 15:36:16 +00:00
|
|
|
// ConstDef
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct ConstDef {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-11 08:03:22 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for ConstDef {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for ConstDef {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-11 08:03:22 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
CONST_DEF => Some(ConstDef::from_repr(syntax.into_repr())),
|
2018-08-11 08:03:22 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<ConstDef> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ast::VisibilityOwner for ConstDef {}
|
|
|
|
impl ast::NameOwner for ConstDef {}
|
|
|
|
impl ast::TypeParamsOwner for ConstDef {}
|
|
|
|
impl ast::AttrsOwner for ConstDef {}
|
|
|
|
impl ast::DocCommentsOwner for ConstDef {}
|
|
|
|
impl ConstDef {}
|
2018-08-11 08:03:22 +00:00
|
|
|
|
2018-08-25 10:42:40 +00:00
|
|
|
// ContinueExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct ContinueExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for ContinueExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for ContinueExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
CONTINUE_EXPR => Some(ContinueExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<ContinueExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ContinueExpr {}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// DynTraitType
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct DynTraitType {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-14 09:38:20 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for DynTraitType {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for DynTraitType {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-14 09:38:20 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
DYN_TRAIT_TYPE => Some(DynTraitType::from_repr(syntax.into_repr())),
|
2018-08-14 09:38:20 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<DynTraitType> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl DynTraitType {}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// EnumDef
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct EnumDef {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for EnumDef {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for EnumDef {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-11 07:56:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
ENUM_DEF => Some(EnumDef::from_repr(syntax.into_repr())),
|
2018-08-11 07:56:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<EnumDef> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ast::VisibilityOwner for EnumDef {}
|
|
|
|
impl ast::NameOwner for EnumDef {}
|
|
|
|
impl ast::TypeParamsOwner for EnumDef {}
|
|
|
|
impl ast::AttrsOwner for EnumDef {}
|
|
|
|
impl ast::DocCommentsOwner for EnumDef {}
|
|
|
|
impl EnumDef {
|
|
|
|
pub fn variant_list(&self) -> Option<&EnumVariantList> {
|
2018-12-25 12:01:47 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// EnumVariant
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct EnumVariant {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-12-25 12:01:47 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for EnumVariant {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-12-25 12:01:47 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for EnumVariant {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-12-25 12:01:47 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
ENUM_VARIANT => Some(EnumVariant::from_repr(syntax.into_repr())),
|
2018-12-25 12:01:47 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<EnumVariant> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-12-25 12:01:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ast::NameOwner for EnumVariant {}
|
|
|
|
impl EnumVariant {
|
|
|
|
pub fn expr(&self) -> Option<&Expr> {
|
2018-12-25 12:01:47 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// EnumVariantList
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct EnumVariantList {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-12-25 12:01:47 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for EnumVariantList {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-12-25 12:01:47 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for EnumVariantList {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-12-25 12:01:47 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
ENUM_VARIANT_LIST => Some(EnumVariantList::from_repr(syntax.into_repr())),
|
2018-12-25 12:01:47 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<EnumVariantList> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-12-25 12:01:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl EnumVariantList {
|
|
|
|
pub fn variants(&self) -> impl Iterator<Item = &EnumVariant> {
|
2018-12-25 12:01:47 +00:00
|
|
|
super::children(self)
|
|
|
|
}
|
|
|
|
}
|
2018-08-11 07:56:40 +00:00
|
|
|
|
2018-08-25 10:42:40 +00:00
|
|
|
// Expr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct Expr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
|
|
|
}
|
|
|
|
unsafe impl TransparentNewType for Expr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-08-25 10:42:40 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
|
|
|
|
pub enum ExprKind<'a> {
|
|
|
|
TupleExpr(&'a TupleExpr),
|
|
|
|
ArrayExpr(&'a ArrayExpr),
|
|
|
|
ParenExpr(&'a ParenExpr),
|
|
|
|
PathExpr(&'a PathExpr),
|
|
|
|
LambdaExpr(&'a LambdaExpr),
|
|
|
|
IfExpr(&'a IfExpr),
|
|
|
|
LoopExpr(&'a LoopExpr),
|
|
|
|
ForExpr(&'a ForExpr),
|
|
|
|
WhileExpr(&'a WhileExpr),
|
|
|
|
ContinueExpr(&'a ContinueExpr),
|
|
|
|
BreakExpr(&'a BreakExpr),
|
|
|
|
Label(&'a Label),
|
|
|
|
BlockExpr(&'a BlockExpr),
|
|
|
|
ReturnExpr(&'a ReturnExpr),
|
|
|
|
MatchExpr(&'a MatchExpr),
|
|
|
|
StructLit(&'a StructLit),
|
|
|
|
CallExpr(&'a CallExpr),
|
|
|
|
IndexExpr(&'a IndexExpr),
|
|
|
|
MethodCallExpr(&'a MethodCallExpr),
|
|
|
|
FieldExpr(&'a FieldExpr),
|
|
|
|
TryExpr(&'a TryExpr),
|
|
|
|
CastExpr(&'a CastExpr),
|
|
|
|
RefExpr(&'a RefExpr),
|
|
|
|
PrefixExpr(&'a PrefixExpr),
|
|
|
|
RangeExpr(&'a RangeExpr),
|
|
|
|
BinExpr(&'a BinExpr),
|
2019-01-14 18:30:21 +00:00
|
|
|
Literal(&'a Literal),
|
2019-01-07 13:16:02 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
impl AstNode for Expr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
|
|
|
match syntax.kind() {
|
|
|
|
| TUPLE_EXPR
|
|
|
|
| ARRAY_EXPR
|
|
|
|
| PAREN_EXPR
|
|
|
|
| PATH_EXPR
|
|
|
|
| LAMBDA_EXPR
|
|
|
|
| IF_EXPR
|
|
|
|
| LOOP_EXPR
|
|
|
|
| FOR_EXPR
|
|
|
|
| WHILE_EXPR
|
|
|
|
| CONTINUE_EXPR
|
|
|
|
| BREAK_EXPR
|
|
|
|
| LABEL
|
|
|
|
| BLOCK_EXPR
|
|
|
|
| RETURN_EXPR
|
|
|
|
| MATCH_EXPR
|
|
|
|
| STRUCT_LIT
|
|
|
|
| CALL_EXPR
|
|
|
|
| INDEX_EXPR
|
|
|
|
| METHOD_CALL_EXPR
|
|
|
|
| FIELD_EXPR
|
|
|
|
| TRY_EXPR
|
|
|
|
| CAST_EXPR
|
|
|
|
| REF_EXPR
|
|
|
|
| PREFIX_EXPR
|
|
|
|
| RANGE_EXPR
|
|
|
|
| BIN_EXPR
|
2019-01-14 18:30:21 +00:00
|
|
|
| LITERAL => Some(Expr::from_repr(syntax.into_repr())),
|
2019-01-07 13:16:02 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<Expr> { TreeArc::cast(self.syntax.to_owned()) }
|
2019-01-07 13:16:02 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
impl Expr {
|
|
|
|
pub fn kind(&self) -> ExprKind {
|
|
|
|
match self.syntax.kind() {
|
|
|
|
TUPLE_EXPR => ExprKind::TupleExpr(TupleExpr::cast(&self.syntax).unwrap()),
|
|
|
|
ARRAY_EXPR => ExprKind::ArrayExpr(ArrayExpr::cast(&self.syntax).unwrap()),
|
|
|
|
PAREN_EXPR => ExprKind::ParenExpr(ParenExpr::cast(&self.syntax).unwrap()),
|
|
|
|
PATH_EXPR => ExprKind::PathExpr(PathExpr::cast(&self.syntax).unwrap()),
|
|
|
|
LAMBDA_EXPR => ExprKind::LambdaExpr(LambdaExpr::cast(&self.syntax).unwrap()),
|
|
|
|
IF_EXPR => ExprKind::IfExpr(IfExpr::cast(&self.syntax).unwrap()),
|
|
|
|
LOOP_EXPR => ExprKind::LoopExpr(LoopExpr::cast(&self.syntax).unwrap()),
|
|
|
|
FOR_EXPR => ExprKind::ForExpr(ForExpr::cast(&self.syntax).unwrap()),
|
|
|
|
WHILE_EXPR => ExprKind::WhileExpr(WhileExpr::cast(&self.syntax).unwrap()),
|
|
|
|
CONTINUE_EXPR => ExprKind::ContinueExpr(ContinueExpr::cast(&self.syntax).unwrap()),
|
|
|
|
BREAK_EXPR => ExprKind::BreakExpr(BreakExpr::cast(&self.syntax).unwrap()),
|
|
|
|
LABEL => ExprKind::Label(Label::cast(&self.syntax).unwrap()),
|
|
|
|
BLOCK_EXPR => ExprKind::BlockExpr(BlockExpr::cast(&self.syntax).unwrap()),
|
|
|
|
RETURN_EXPR => ExprKind::ReturnExpr(ReturnExpr::cast(&self.syntax).unwrap()),
|
|
|
|
MATCH_EXPR => ExprKind::MatchExpr(MatchExpr::cast(&self.syntax).unwrap()),
|
|
|
|
STRUCT_LIT => ExprKind::StructLit(StructLit::cast(&self.syntax).unwrap()),
|
|
|
|
CALL_EXPR => ExprKind::CallExpr(CallExpr::cast(&self.syntax).unwrap()),
|
|
|
|
INDEX_EXPR => ExprKind::IndexExpr(IndexExpr::cast(&self.syntax).unwrap()),
|
|
|
|
METHOD_CALL_EXPR => ExprKind::MethodCallExpr(MethodCallExpr::cast(&self.syntax).unwrap()),
|
|
|
|
FIELD_EXPR => ExprKind::FieldExpr(FieldExpr::cast(&self.syntax).unwrap()),
|
|
|
|
TRY_EXPR => ExprKind::TryExpr(TryExpr::cast(&self.syntax).unwrap()),
|
|
|
|
CAST_EXPR => ExprKind::CastExpr(CastExpr::cast(&self.syntax).unwrap()),
|
|
|
|
REF_EXPR => ExprKind::RefExpr(RefExpr::cast(&self.syntax).unwrap()),
|
|
|
|
PREFIX_EXPR => ExprKind::PrefixExpr(PrefixExpr::cast(&self.syntax).unwrap()),
|
|
|
|
RANGE_EXPR => ExprKind::RangeExpr(RangeExpr::cast(&self.syntax).unwrap()),
|
|
|
|
BIN_EXPR => ExprKind::BinExpr(BinExpr::cast(&self.syntax).unwrap()),
|
2019-01-14 18:30:21 +00:00
|
|
|
LITERAL => ExprKind::Literal(Literal::cast(&self.syntax).unwrap()),
|
2019-01-07 13:16:02 +00:00
|
|
|
_ => unreachable!(),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Expr {}
|
2018-08-25 10:42:40 +00:00
|
|
|
|
2018-08-27 07:01:31 +00:00
|
|
|
// ExprStmt
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct ExprStmt {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for ExprStmt {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for ExprStmt {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-27 07:01:31 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
EXPR_STMT => Some(ExprStmt::from_repr(syntax.into_repr())),
|
2018-08-27 07:01:31 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<ExprStmt> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-27 09:22:09 +00:00
|
|
|
}
|
2018-08-27 07:01:31 +00:00
|
|
|
|
2018-10-31 07:27:53 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ExprStmt {
|
|
|
|
pub fn expr(&self) -> Option<&Expr> {
|
2018-11-06 18:52:00 +00:00
|
|
|
super::child_opt(self)
|
2018-10-31 07:27:53 +00:00
|
|
|
}
|
|
|
|
}
|
2018-11-01 10:41:04 +00:00
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
// ExternCrateItem
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct ExternCrateItem {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for ExternCrateItem {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for ExternCrateItem {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-28 08:12:42 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
EXTERN_CRATE_ITEM => Some(ExternCrateItem::from_repr(syntax.into_repr())),
|
2018-08-28 08:12:42 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<ExternCrateItem> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ExternCrateItem {}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2019-01-14 18:30:21 +00:00
|
|
|
// FalseKw
|
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct FalseKw {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
|
|
|
}
|
|
|
|
unsafe impl TransparentNewType for FalseKw {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
|
|
|
}
|
|
|
|
|
|
|
|
impl AstNode for FalseKw {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
|
|
|
match syntax.kind() {
|
|
|
|
FALSE_KW => Some(FalseKw::from_repr(syntax.into_repr())),
|
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
|
|
|
fn to_owned(&self) -> TreeArc<FalseKw> { TreeArc::cast(self.syntax.to_owned()) }
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
impl ast::AstToken for FalseKw {}
|
|
|
|
impl FalseKw {}
|
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
// FieldExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct FieldExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for FieldExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for FieldExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
FIELD_EXPR => Some(FieldExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<FieldExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl FieldExpr {
|
|
|
|
pub fn expr(&self) -> Option<&Expr> {
|
2018-12-25 12:54:38 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn name_ref(&self) -> Option<&NameRef> {
|
2018-12-25 12:54:38 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2019-01-18 13:52:31 +00:00
|
|
|
// FieldPat
|
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct FieldPat {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
|
|
|
}
|
|
|
|
unsafe impl TransparentNewType for FieldPat {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
|
|
|
}
|
|
|
|
|
|
|
|
impl AstNode for FieldPat {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
|
|
|
match syntax.kind() {
|
|
|
|
FIELD_PAT => Some(FieldPat::from_repr(syntax.into_repr())),
|
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
|
|
|
fn to_owned(&self) -> TreeArc<FieldPat> { TreeArc::cast(self.syntax.to_owned()) }
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
impl ast::NameOwner for FieldPat {}
|
|
|
|
impl FieldPat {
|
|
|
|
pub fn pat(&self) -> Option<&Pat> {
|
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
// FieldPatList
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct FieldPatList {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for FieldPatList {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for FieldPatList {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-26 09:09:28 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
FIELD_PAT_LIST => Some(FieldPatList::from_repr(syntax.into_repr())),
|
2018-08-26 09:09:28 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<FieldPatList> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-18 13:52:31 +00:00
|
|
|
impl FieldPatList {
|
2019-01-19 00:02:38 +00:00
|
|
|
pub fn field_pats(&self) -> impl Iterator<Item = &FieldPat> {
|
|
|
|
super::children(self)
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn bind_pats(&self) -> impl Iterator<Item = &BindPat> {
|
2019-01-18 13:52:31 +00:00
|
|
|
super::children(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2019-01-11 10:27:07 +00:00
|
|
|
// FloatNumber
|
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct FloatNumber {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
|
|
|
}
|
|
|
|
unsafe impl TransparentNewType for FloatNumber {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
|
|
|
}
|
|
|
|
|
|
|
|
impl AstNode for FloatNumber {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
|
|
|
match syntax.kind() {
|
|
|
|
FLOAT_NUMBER => Some(FloatNumber::from_repr(syntax.into_repr())),
|
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-14 18:30:21 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<FloatNumber> { TreeArc::cast(self.syntax.to_owned()) }
|
2019-01-11 10:27:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
impl ast::AstToken for FloatNumber {}
|
|
|
|
impl FloatNumber {}
|
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
// FnDef
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct FnDef {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for FnDef {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for FnDef {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-09 14:43:39 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
FN_DEF => Some(FnDef::from_repr(syntax.into_repr())),
|
2018-08-09 14:43:39 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<FnDef> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ast::VisibilityOwner for FnDef {}
|
|
|
|
impl ast::NameOwner for FnDef {}
|
|
|
|
impl ast::TypeParamsOwner for FnDef {}
|
|
|
|
impl ast::AttrsOwner for FnDef {}
|
|
|
|
impl ast::DocCommentsOwner for FnDef {}
|
|
|
|
impl FnDef {
|
|
|
|
pub fn param_list(&self) -> Option<&ParamList> {
|
2018-08-26 09:09:28 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2018-10-10 15:26:01 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn body(&self) -> Option<&Block> {
|
2018-08-27 07:01:31 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2018-10-10 15:26:01 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn ret_type(&self) -> Option<&RetType> {
|
2018-08-28 18:11:17 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2018-08-26 09:09:28 +00:00
|
|
|
}
|
2018-08-11 06:55:32 +00:00
|
|
|
|
2018-08-14 09:38:20 +00:00
|
|
|
// FnPointerType
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct FnPointerType {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for FnPointerType {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for FnPointerType {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-14 09:38:20 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
FN_POINTER_TYPE => Some(FnPointerType::from_repr(syntax.into_repr())),
|
2018-08-14 09:38:20 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<FnPointerType> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl FnPointerType {
|
|
|
|
pub fn param_list(&self) -> Option<&ParamList> {
|
2018-12-25 20:14:13 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn ret_type(&self) -> Option<&RetType> {
|
2018-12-25 20:14:13 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// ForExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct ForExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for ForExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for ForExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
FOR_EXPR => Some(ForExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<ForExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ast::LoopBodyOwner for ForExpr {}
|
|
|
|
impl ForExpr {
|
|
|
|
pub fn pat(&self) -> Option<&Pat> {
|
2018-08-27 19:03:19 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2018-10-10 15:26:01 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn iterable(&self) -> Option<&Expr> {
|
2018-08-27 19:03:19 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2018-08-27 09:22:09 +00:00
|
|
|
}
|
2018-08-25 10:42:40 +00:00
|
|
|
|
2018-08-14 09:38:20 +00:00
|
|
|
// ForType
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct ForType {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for ForType {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for ForType {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-14 09:38:20 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
FOR_TYPE => Some(ForType::from_repr(syntax.into_repr())),
|
2018-08-14 09:38:20 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<ForType> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ForType {
|
|
|
|
pub fn type_ref(&self) -> Option<&TypeRef> {
|
2018-12-25 20:14:13 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// IfExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct IfExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for IfExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for IfExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
IF_EXPR => Some(IfExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<IfExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-27 09:22:09 +00:00
|
|
|
}
|
2018-08-25 10:42:40 +00:00
|
|
|
|
2018-10-31 07:27:53 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl IfExpr {
|
|
|
|
pub fn condition(&self) -> Option<&Condition> {
|
2018-11-06 18:52:00 +00:00
|
|
|
super::child_opt(self)
|
2018-10-31 07:27:53 +00:00
|
|
|
}
|
|
|
|
}
|
2018-11-01 10:41:04 +00:00
|
|
|
|
2018-12-26 20:24:49 +00:00
|
|
|
// ImplBlock
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct ImplBlock {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for ImplBlock {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for ImplBlock {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-14 08:20:09 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
IMPL_BLOCK => Some(ImplBlock::from_repr(syntax.into_repr())),
|
2018-08-14 08:20:09 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<ImplBlock> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ImplBlock {
|
|
|
|
pub fn item_list(&self) -> Option<&ItemList> {
|
2018-12-28 13:34:00 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// ImplItem
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct ImplItem {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
|
|
|
}
|
|
|
|
unsafe impl TransparentNewType for ImplItem {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
|
|
|
}
|
|
|
|
|
2018-12-28 13:34:00 +00:00
|
|
|
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
|
2019-01-07 13:16:02 +00:00
|
|
|
pub enum ImplItemKind<'a> {
|
|
|
|
FnDef(&'a FnDef),
|
|
|
|
TypeDef(&'a TypeDef),
|
|
|
|
ConstDef(&'a ConstDef),
|
2018-12-28 13:34:00 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for ImplItem {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-12-28 13:34:00 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
| FN_DEF
|
|
|
|
| TYPE_DEF
|
|
|
|
| CONST_DEF => Some(ImplItem::from_repr(syntax.into_repr())),
|
2018-12-28 13:34:00 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<ImplItem> { TreeArc::cast(self.syntax.to_owned()) }
|
2019-01-07 13:16:02 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
impl ImplItem {
|
|
|
|
pub fn kind(&self) -> ImplItemKind {
|
|
|
|
match self.syntax.kind() {
|
|
|
|
FN_DEF => ImplItemKind::FnDef(FnDef::cast(&self.syntax).unwrap()),
|
|
|
|
TYPE_DEF => ImplItemKind::TypeDef(TypeDef::cast(&self.syntax).unwrap()),
|
|
|
|
CONST_DEF => ImplItemKind::ConstDef(ConstDef::cast(&self.syntax).unwrap()),
|
|
|
|
_ => unreachable!(),
|
2018-12-28 13:34:00 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ImplItem {}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// ImplTraitType
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct ImplTraitType {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for ImplTraitType {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for ImplTraitType {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-14 09:38:20 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
IMPL_TRAIT_TYPE => Some(ImplTraitType::from_repr(syntax.into_repr())),
|
2018-08-14 09:38:20 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<ImplTraitType> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ImplTraitType {}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// IndexExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct IndexExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-25 10:42:40 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for IndexExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for IndexExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
INDEX_EXPR => Some(IndexExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<IndexExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl IndexExpr {}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2019-01-11 10:27:07 +00:00
|
|
|
// IntNumber
|
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct IntNumber {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
|
|
|
}
|
|
|
|
unsafe impl TransparentNewType for IntNumber {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
|
|
|
}
|
|
|
|
|
|
|
|
impl AstNode for IntNumber {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
|
|
|
match syntax.kind() {
|
|
|
|
INT_NUMBER => Some(IntNumber::from_repr(syntax.into_repr())),
|
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-14 18:30:21 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<IntNumber> { TreeArc::cast(self.syntax.to_owned()) }
|
2019-01-11 10:27:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
impl ast::AstToken for IntNumber {}
|
|
|
|
impl IntNumber {}
|
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
// ItemList
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct ItemList {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for ItemList {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for ItemList {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-09-03 12:10:06 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
ITEM_LIST => Some(ItemList::from_repr(syntax.into_repr())),
|
2018-09-03 12:10:06 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<ItemList> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ast::FnDefOwner for ItemList {}
|
|
|
|
impl ast::ModuleItemOwner for ItemList {}
|
|
|
|
impl ItemList {
|
|
|
|
pub fn impl_items(&self) -> impl Iterator<Item = &ImplItem> {
|
2018-12-28 13:34:00 +00:00
|
|
|
super::children(self)
|
|
|
|
}
|
|
|
|
}
|
2018-09-03 12:10:06 +00:00
|
|
|
|
2018-08-25 10:42:40 +00:00
|
|
|
// Label
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct Label {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-25 10:42:40 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for Label {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for Label {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
LABEL => Some(Label::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<Label> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl Label {}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// LambdaExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct LambdaExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for LambdaExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for LambdaExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
LAMBDA_EXPR => Some(LambdaExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<LambdaExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl LambdaExpr {
|
|
|
|
pub fn param_list(&self) -> Option<&ParamList> {
|
2018-08-28 20:59:57 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2018-10-10 15:26:01 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn body(&self) -> Option<&Expr> {
|
2018-08-28 20:59:57 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-08-25 10:42:40 +00:00
|
|
|
|
2018-08-26 09:09:28 +00:00
|
|
|
// LetStmt
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct LetStmt {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-26 09:09:28 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for LetStmt {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for LetStmt {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-26 09:09:28 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
LET_STMT => Some(LetStmt::from_repr(syntax.into_repr())),
|
2018-08-26 09:09:28 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<LetStmt> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl LetStmt {
|
|
|
|
pub fn pat(&self) -> Option<&Pat> {
|
2018-08-26 09:09:28 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2018-10-10 15:26:01 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn type_ref(&self) -> Option<&TypeRef> {
|
2018-12-23 12:22:29 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn initializer(&self) -> Option<&Expr> {
|
2018-08-27 07:01:31 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2018-08-26 09:09:28 +00:00
|
|
|
}
|
|
|
|
|
2018-08-28 20:59:57 +00:00
|
|
|
// Lifetime
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct Lifetime {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for Lifetime {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for Lifetime {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-28 20:59:57 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
LIFETIME => Some(Lifetime::from_repr(syntax.into_repr())),
|
2018-08-28 20:59:57 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<Lifetime> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-08 09:23:10 +00:00
|
|
|
impl ast::AstToken for Lifetime {}
|
2019-01-07 13:16:02 +00:00
|
|
|
impl Lifetime {}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// LifetimeParam
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct LifetimeParam {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-28 20:59:57 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for LifetimeParam {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for LifetimeParam {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-28 20:59:57 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
LIFETIME_PARAM => Some(LifetimeParam::from_repr(syntax.into_repr())),
|
2018-08-28 20:59:57 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<LifetimeParam> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-28 20:59:57 +00:00
|
|
|
}
|
|
|
|
|
2018-10-31 07:27:53 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl LifetimeParam {
|
|
|
|
pub fn lifetime(&self) -> Option<&Lifetime> {
|
2018-11-06 18:52:00 +00:00
|
|
|
super::child_opt(self)
|
2018-10-31 07:27:53 +00:00
|
|
|
}
|
|
|
|
}
|
2018-11-01 10:41:04 +00:00
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
// Literal
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct Literal {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for Literal {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for Literal {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-28 11:21:37 +00:00
|
|
|
match syntax.kind() {
|
2019-01-14 18:30:21 +00:00
|
|
|
LITERAL => Some(Literal::from_repr(syntax.into_repr())),
|
2018-08-28 11:21:37 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<Literal> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2019-01-14 18:30:21 +00:00
|
|
|
|
2019-01-11 10:27:07 +00:00
|
|
|
impl Literal {
|
2019-01-14 18:30:21 +00:00
|
|
|
pub fn literal_expr(&self) -> Option<&LiteralExpr> {
|
|
|
|
super::child_opt(self)
|
2019-01-11 10:27:07 +00:00
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2019-01-11 10:27:07 +00:00
|
|
|
// LiteralExpr
|
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct LiteralExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
|
|
|
}
|
|
|
|
unsafe impl TransparentNewType for LiteralExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
|
|
|
}
|
|
|
|
|
2019-01-14 18:30:21 +00:00
|
|
|
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
|
|
|
|
pub enum LiteralExprKind<'a> {
|
|
|
|
String(&'a String),
|
|
|
|
ByteString(&'a ByteString),
|
2019-01-14 19:56:14 +00:00
|
|
|
RawString(&'a RawString),
|
|
|
|
RawByteString(&'a RawByteString),
|
2019-01-14 18:30:21 +00:00
|
|
|
Char(&'a Char),
|
|
|
|
Byte(&'a Byte),
|
|
|
|
IntNumber(&'a IntNumber),
|
|
|
|
FloatNumber(&'a FloatNumber),
|
|
|
|
TrueKw(&'a TrueKw),
|
|
|
|
FalseKw(&'a FalseKw),
|
|
|
|
}
|
|
|
|
|
2019-01-11 10:27:07 +00:00
|
|
|
impl AstNode for LiteralExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
|
|
|
match syntax.kind() {
|
2019-01-14 18:30:21 +00:00
|
|
|
| STRING
|
|
|
|
| BYTE_STRING
|
2019-01-14 19:56:14 +00:00
|
|
|
| RAW_STRING
|
|
|
|
| RAW_BYTE_STRING
|
2019-01-14 18:30:21 +00:00
|
|
|
| CHAR
|
|
|
|
| BYTE
|
|
|
|
| INT_NUMBER
|
|
|
|
| FLOAT_NUMBER
|
|
|
|
| TRUE_KW
|
|
|
|
| FALSE_KW => Some(LiteralExpr::from_repr(syntax.into_repr())),
|
2019-01-11 10:27:07 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-14 18:30:21 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<LiteralExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2019-01-11 10:27:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
impl LiteralExpr {
|
2019-01-14 18:30:21 +00:00
|
|
|
pub fn kind(&self) -> LiteralExprKind {
|
|
|
|
match self.syntax.kind() {
|
|
|
|
STRING => LiteralExprKind::String(String::cast(&self.syntax).unwrap()),
|
|
|
|
BYTE_STRING => LiteralExprKind::ByteString(ByteString::cast(&self.syntax).unwrap()),
|
2019-01-14 19:56:14 +00:00
|
|
|
RAW_STRING => LiteralExprKind::RawString(RawString::cast(&self.syntax).unwrap()),
|
|
|
|
RAW_BYTE_STRING => LiteralExprKind::RawByteString(RawByteString::cast(&self.syntax).unwrap()),
|
2019-01-14 18:30:21 +00:00
|
|
|
CHAR => LiteralExprKind::Char(Char::cast(&self.syntax).unwrap()),
|
|
|
|
BYTE => LiteralExprKind::Byte(Byte::cast(&self.syntax).unwrap()),
|
|
|
|
INT_NUMBER => LiteralExprKind::IntNumber(IntNumber::cast(&self.syntax).unwrap()),
|
|
|
|
FLOAT_NUMBER => LiteralExprKind::FloatNumber(FloatNumber::cast(&self.syntax).unwrap()),
|
|
|
|
TRUE_KW => LiteralExprKind::TrueKw(TrueKw::cast(&self.syntax).unwrap()),
|
|
|
|
FALSE_KW => LiteralExprKind::FalseKw(FalseKw::cast(&self.syntax).unwrap()),
|
|
|
|
_ => unreachable!(),
|
|
|
|
}
|
2019-01-11 10:27:07 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-01-14 18:30:21 +00:00
|
|
|
impl LiteralExpr {}
|
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
// LoopExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct LoopExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-25 10:42:40 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for LoopExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for LoopExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
LOOP_EXPR => Some(LoopExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<LoopExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ast::LoopBodyOwner for LoopExpr {}
|
|
|
|
impl LoopExpr {}
|
2018-08-25 10:42:40 +00:00
|
|
|
|
2018-12-28 10:27:30 +00:00
|
|
|
// MacroCall
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct MacroCall {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-12-28 10:27:30 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for MacroCall {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-12-28 10:27:30 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for MacroCall {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-12-28 10:27:30 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
MACRO_CALL => Some(MacroCall::from_repr(syntax.into_repr())),
|
2018-12-28 10:27:30 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<MacroCall> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-12-28 10:27:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl MacroCall {
|
|
|
|
pub fn token_tree(&self) -> Option<&TokenTree> {
|
2018-12-28 10:27:30 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2018-12-28 13:59:58 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn path(&self) -> Option<&Path> {
|
2018-12-28 13:59:58 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2018-12-28 10:27:30 +00:00
|
|
|
}
|
|
|
|
|
2018-08-25 10:42:40 +00:00
|
|
|
// MatchArm
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct MatchArm {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for MatchArm {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for MatchArm {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
MATCH_ARM => Some(MatchArm::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<MatchArm> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-25 10:42:40 +00:00
|
|
|
}
|
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl MatchArm {
|
|
|
|
pub fn pats(&self) -> impl Iterator<Item = &Pat> {
|
2018-09-02 22:51:46 +00:00
|
|
|
super::children(self)
|
|
|
|
}
|
2018-10-10 15:26:01 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn guard(&self) -> Option<&MatchGuard> {
|
2018-09-02 22:51:46 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2018-10-10 15:26:01 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn expr(&self) -> Option<&Expr> {
|
2018-09-02 22:51:46 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-08-25 10:42:40 +00:00
|
|
|
|
|
|
|
// MatchArmList
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct MatchArmList {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for MatchArmList {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for MatchArmList {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
MATCH_ARM_LIST => Some(MatchArmList::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<MatchArmList> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-25 10:42:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl MatchArmList {
|
|
|
|
pub fn arms(&self) -> impl Iterator<Item = &MatchArm> {
|
2018-11-06 18:52:00 +00:00
|
|
|
super::children(self)
|
2018-10-31 07:27:53 +00:00
|
|
|
}
|
|
|
|
}
|
2018-11-01 10:41:04 +00:00
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
// MatchExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct MatchExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for MatchExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for MatchExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
MATCH_EXPR => Some(MatchExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<MatchExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl MatchExpr {
|
|
|
|
pub fn expr(&self) -> Option<&Expr> {
|
2018-09-02 22:51:46 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2018-10-10 15:26:01 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn match_arm_list(&self) -> Option<&MatchArmList> {
|
2018-09-02 22:51:46 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-08-25 10:42:40 +00:00
|
|
|
|
|
|
|
// MatchGuard
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct MatchGuard {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-25 10:42:40 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for MatchGuard {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for MatchGuard {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
MATCH_GUARD => Some(MatchGuard::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<MatchGuard> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-10-31 07:27:53 +00:00
|
|
|
}
|
2018-11-01 10:41:04 +00:00
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl MatchGuard {}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// MethodCallExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct MethodCallExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-25 10:42:40 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for MethodCallExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for MethodCallExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
METHOD_CALL_EXPR => Some(MethodCallExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<MethodCallExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ast::ArgListOwner for MethodCallExpr {}
|
|
|
|
impl MethodCallExpr {
|
|
|
|
pub fn expr(&self) -> Option<&Expr> {
|
2018-09-02 23:01:43 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2018-12-25 14:15:40 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn name_ref(&self) -> Option<&NameRef> {
|
2018-12-25 14:15:40 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2018-09-02 23:01:43 +00:00
|
|
|
}
|
2018-08-25 10:42:40 +00:00
|
|
|
|
2018-08-11 09:28:59 +00:00
|
|
|
// Module
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct Module {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-11 08:03:22 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for Module {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for Module {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-11 08:03:22 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
MODULE => Some(Module::from_repr(syntax.into_repr())),
|
2018-08-11 08:03:22 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<Module> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ast::VisibilityOwner for Module {}
|
|
|
|
impl ast::NameOwner for Module {}
|
|
|
|
impl ast::AttrsOwner for Module {}
|
|
|
|
impl ast::DocCommentsOwner for Module {}
|
|
|
|
impl Module {
|
|
|
|
pub fn item_list(&self) -> Option<&ItemList> {
|
2018-09-03 12:10:06 +00:00
|
|
|
super::child_opt(self)
|
2018-08-21 15:30:10 +00:00
|
|
|
}
|
|
|
|
}
|
2018-08-11 08:03:22 +00:00
|
|
|
|
2018-08-28 08:12:42 +00:00
|
|
|
// ModuleItem
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct ModuleItem {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
|
|
|
}
|
|
|
|
unsafe impl TransparentNewType for ModuleItem {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-08-28 08:12:42 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
|
|
|
|
pub enum ModuleItemKind<'a> {
|
|
|
|
StructDef(&'a StructDef),
|
|
|
|
EnumDef(&'a EnumDef),
|
|
|
|
FnDef(&'a FnDef),
|
|
|
|
TraitDef(&'a TraitDef),
|
|
|
|
TypeDef(&'a TypeDef),
|
|
|
|
ImplBlock(&'a ImplBlock),
|
|
|
|
UseItem(&'a UseItem),
|
|
|
|
ExternCrateItem(&'a ExternCrateItem),
|
|
|
|
ConstDef(&'a ConstDef),
|
|
|
|
StaticDef(&'a StaticDef),
|
|
|
|
Module(&'a Module),
|
|
|
|
}
|
|
|
|
|
|
|
|
impl AstNode for ModuleItem {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
|
|
|
match syntax.kind() {
|
|
|
|
| STRUCT_DEF
|
|
|
|
| ENUM_DEF
|
|
|
|
| FN_DEF
|
|
|
|
| TRAIT_DEF
|
|
|
|
| TYPE_DEF
|
|
|
|
| IMPL_BLOCK
|
|
|
|
| USE_ITEM
|
|
|
|
| EXTERN_CRATE_ITEM
|
|
|
|
| CONST_DEF
|
|
|
|
| STATIC_DEF
|
|
|
|
| MODULE => Some(ModuleItem::from_repr(syntax.into_repr())),
|
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<ModuleItem> { TreeArc::cast(self.syntax.to_owned()) }
|
2019-01-07 13:16:02 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
impl ModuleItem {
|
|
|
|
pub fn kind(&self) -> ModuleItemKind {
|
|
|
|
match self.syntax.kind() {
|
|
|
|
STRUCT_DEF => ModuleItemKind::StructDef(StructDef::cast(&self.syntax).unwrap()),
|
|
|
|
ENUM_DEF => ModuleItemKind::EnumDef(EnumDef::cast(&self.syntax).unwrap()),
|
|
|
|
FN_DEF => ModuleItemKind::FnDef(FnDef::cast(&self.syntax).unwrap()),
|
|
|
|
TRAIT_DEF => ModuleItemKind::TraitDef(TraitDef::cast(&self.syntax).unwrap()),
|
|
|
|
TYPE_DEF => ModuleItemKind::TypeDef(TypeDef::cast(&self.syntax).unwrap()),
|
|
|
|
IMPL_BLOCK => ModuleItemKind::ImplBlock(ImplBlock::cast(&self.syntax).unwrap()),
|
|
|
|
USE_ITEM => ModuleItemKind::UseItem(UseItem::cast(&self.syntax).unwrap()),
|
|
|
|
EXTERN_CRATE_ITEM => ModuleItemKind::ExternCrateItem(ExternCrateItem::cast(&self.syntax).unwrap()),
|
|
|
|
CONST_DEF => ModuleItemKind::ConstDef(ConstDef::cast(&self.syntax).unwrap()),
|
|
|
|
STATIC_DEF => ModuleItemKind::StaticDef(StaticDef::cast(&self.syntax).unwrap()),
|
|
|
|
MODULE => ModuleItemKind::Module(Module::cast(&self.syntax).unwrap()),
|
|
|
|
_ => unreachable!(),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl ModuleItem {}
|
2018-08-28 08:12:42 +00:00
|
|
|
|
2018-08-11 09:28:59 +00:00
|
|
|
// Name
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct Name {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for Name {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for Name {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-09 14:43:39 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
NAME => Some(Name::from_repr(syntax.into_repr())),
|
2018-08-09 14:43:39 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<Name> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl Name {}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// NameRef
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct NameRef {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-13 13:35:17 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for NameRef {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for NameRef {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-13 13:35:17 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
NAME_REF => Some(NameRef::from_repr(syntax.into_repr())),
|
2018-08-13 13:35:17 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<NameRef> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl NameRef {}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// NamedField
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct NamedField {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-25 10:42:40 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for NamedField {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for NamedField {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
NAMED_FIELD => Some(NamedField::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<NamedField> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl NamedField {
|
|
|
|
pub fn name_ref(&self) -> Option<&NameRef> {
|
2018-12-24 20:00:14 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn expr(&self) -> Option<&Expr> {
|
2018-12-24 20:00:14 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// NamedFieldDef
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct NamedFieldDef {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-14 11:45:56 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for NamedFieldDef {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for NamedFieldDef {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-14 11:45:56 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
NAMED_FIELD_DEF => Some(NamedFieldDef::from_repr(syntax.into_repr())),
|
2018-08-14 11:45:56 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<NamedFieldDef> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-14 11:45:56 +00:00
|
|
|
}
|
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ast::VisibilityOwner for NamedFieldDef {}
|
|
|
|
impl ast::NameOwner for NamedFieldDef {}
|
|
|
|
impl ast::AttrsOwner for NamedFieldDef {}
|
|
|
|
impl NamedFieldDef {
|
|
|
|
pub fn type_ref(&self) -> Option<&TypeRef> {
|
2018-12-25 12:01:47 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// NamedFieldDefList
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct NamedFieldDefList {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-12-25 12:01:47 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for NamedFieldDefList {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-12-25 12:01:47 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for NamedFieldDefList {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-12-25 12:01:47 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
NAMED_FIELD_DEF_LIST => Some(NamedFieldDefList::from_repr(syntax.into_repr())),
|
2018-12-25 12:01:47 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<NamedFieldDefList> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-12-25 12:01:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl NamedFieldDefList {
|
|
|
|
pub fn fields(&self) -> impl Iterator<Item = &NamedFieldDef> {
|
2018-12-25 12:01:47 +00:00
|
|
|
super::children(self)
|
|
|
|
}
|
|
|
|
}
|
2018-08-14 11:45:56 +00:00
|
|
|
|
2018-08-25 10:42:40 +00:00
|
|
|
// NamedFieldList
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct NamedFieldList {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for NamedFieldList {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for NamedFieldList {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
NAMED_FIELD_LIST => Some(NamedFieldList::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<NamedFieldList> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl NamedFieldList {
|
|
|
|
pub fn fields(&self) -> impl Iterator<Item = &NamedField> {
|
2018-12-24 20:00:14 +00:00
|
|
|
super::children(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// NeverType
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct NeverType {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-14 09:38:20 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for NeverType {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for NeverType {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-14 09:38:20 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
NEVER_TYPE => Some(NeverType::from_repr(syntax.into_repr())),
|
2018-08-14 09:38:20 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<NeverType> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl NeverType {}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// NominalDef
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct NominalDef {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
|
|
|
}
|
|
|
|
unsafe impl TransparentNewType for NominalDef {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
|
|
|
}
|
|
|
|
|
2018-11-06 19:47:38 +00:00
|
|
|
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
|
2019-01-07 13:16:02 +00:00
|
|
|
pub enum NominalDefKind<'a> {
|
|
|
|
StructDef(&'a StructDef),
|
|
|
|
EnumDef(&'a EnumDef),
|
2018-08-14 10:33:44 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for NominalDef {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-14 10:33:44 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
| STRUCT_DEF
|
|
|
|
| ENUM_DEF => Some(NominalDef::from_repr(syntax.into_repr())),
|
2018-08-14 10:33:44 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<NominalDef> { TreeArc::cast(self.syntax.to_owned()) }
|
2019-01-07 13:16:02 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
impl NominalDef {
|
|
|
|
pub fn kind(&self) -> NominalDefKind {
|
|
|
|
match self.syntax.kind() {
|
|
|
|
STRUCT_DEF => NominalDefKind::StructDef(StructDef::cast(&self.syntax).unwrap()),
|
|
|
|
ENUM_DEF => NominalDefKind::EnumDef(EnumDef::cast(&self.syntax).unwrap()),
|
|
|
|
_ => unreachable!(),
|
2018-08-14 10:33:44 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ast::NameOwner for NominalDef {}
|
|
|
|
impl ast::TypeParamsOwner for NominalDef {}
|
|
|
|
impl ast::AttrsOwner for NominalDef {}
|
|
|
|
impl NominalDef {}
|
2018-08-14 10:33:44 +00:00
|
|
|
|
2018-08-26 09:09:28 +00:00
|
|
|
// Param
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct Param {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for Param {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for Param {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-26 09:09:28 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
PARAM => Some(Param::from_repr(syntax.into_repr())),
|
2018-08-26 09:09:28 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<Param> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-26 09:09:28 +00:00
|
|
|
}
|
|
|
|
|
2018-10-31 07:27:53 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl Param {
|
|
|
|
pub fn pat(&self) -> Option<&Pat> {
|
2018-11-06 18:52:00 +00:00
|
|
|
super::child_opt(self)
|
2018-10-31 07:27:53 +00:00
|
|
|
}
|
2018-12-20 20:56:28 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn type_ref(&self) -> Option<&TypeRef> {
|
2018-12-20 20:56:28 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2018-10-31 07:27:53 +00:00
|
|
|
}
|
2018-11-01 10:41:04 +00:00
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
// ParamList
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct ParamList {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for ParamList {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for ParamList {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-26 09:09:28 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
PARAM_LIST => Some(ParamList::from_repr(syntax.into_repr())),
|
2018-08-26 09:09:28 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<ParamList> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ParamList {
|
|
|
|
pub fn params(&self) -> impl Iterator<Item = &Param> {
|
2018-08-26 09:09:28 +00:00
|
|
|
super::children(self)
|
|
|
|
}
|
2018-10-10 15:26:01 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn self_param(&self) -> Option<&SelfParam> {
|
2018-08-31 13:30:42 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2018-08-26 09:09:28 +00:00
|
|
|
}
|
|
|
|
|
2018-08-25 10:42:40 +00:00
|
|
|
// ParenExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct ParenExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-25 10:42:40 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for ParenExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for ParenExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
PAREN_EXPR => Some(ParenExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<ParenExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ParenExpr {
|
|
|
|
pub fn expr(&self) -> Option<&Expr> {
|
2018-12-20 20:56:28 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// ParenType
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct ParenType {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-14 09:38:20 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for ParenType {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for ParenType {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-14 09:38:20 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
PAREN_TYPE => Some(ParenType::from_repr(syntax.into_repr())),
|
2018-08-14 09:38:20 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<ParenType> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ParenType {
|
|
|
|
pub fn type_ref(&self) -> Option<&TypeRef> {
|
2018-12-25 16:17:39 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// Pat
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct Pat {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
|
|
|
}
|
|
|
|
unsafe impl TransparentNewType for Pat {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
|
|
|
}
|
|
|
|
|
2018-11-06 19:47:38 +00:00
|
|
|
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
|
2019-01-07 13:16:02 +00:00
|
|
|
pub enum PatKind<'a> {
|
|
|
|
RefPat(&'a RefPat),
|
|
|
|
BindPat(&'a BindPat),
|
|
|
|
PlaceholderPat(&'a PlaceholderPat),
|
|
|
|
PathPat(&'a PathPat),
|
|
|
|
StructPat(&'a StructPat),
|
|
|
|
TupleStructPat(&'a TupleStructPat),
|
|
|
|
TuplePat(&'a TuplePat),
|
|
|
|
SlicePat(&'a SlicePat),
|
|
|
|
RangePat(&'a RangePat),
|
|
|
|
}
|
|
|
|
|
|
|
|
impl AstNode for Pat {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-26 09:09:28 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
| REF_PAT
|
|
|
|
| BIND_PAT
|
|
|
|
| PLACEHOLDER_PAT
|
|
|
|
| PATH_PAT
|
|
|
|
| STRUCT_PAT
|
|
|
|
| TUPLE_STRUCT_PAT
|
|
|
|
| TUPLE_PAT
|
|
|
|
| SLICE_PAT
|
|
|
|
| RANGE_PAT => Some(Pat::from_repr(syntax.into_repr())),
|
2018-08-26 09:09:28 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<Pat> { TreeArc::cast(self.syntax.to_owned()) }
|
2019-01-07 13:16:02 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
impl Pat {
|
|
|
|
pub fn kind(&self) -> PatKind {
|
|
|
|
match self.syntax.kind() {
|
|
|
|
REF_PAT => PatKind::RefPat(RefPat::cast(&self.syntax).unwrap()),
|
|
|
|
BIND_PAT => PatKind::BindPat(BindPat::cast(&self.syntax).unwrap()),
|
|
|
|
PLACEHOLDER_PAT => PatKind::PlaceholderPat(PlaceholderPat::cast(&self.syntax).unwrap()),
|
|
|
|
PATH_PAT => PatKind::PathPat(PathPat::cast(&self.syntax).unwrap()),
|
|
|
|
STRUCT_PAT => PatKind::StructPat(StructPat::cast(&self.syntax).unwrap()),
|
|
|
|
TUPLE_STRUCT_PAT => PatKind::TupleStructPat(TupleStructPat::cast(&self.syntax).unwrap()),
|
|
|
|
TUPLE_PAT => PatKind::TuplePat(TuplePat::cast(&self.syntax).unwrap()),
|
|
|
|
SLICE_PAT => PatKind::SlicePat(SlicePat::cast(&self.syntax).unwrap()),
|
|
|
|
RANGE_PAT => PatKind::RangePat(RangePat::cast(&self.syntax).unwrap()),
|
|
|
|
_ => unreachable!(),
|
2018-08-26 09:09:28 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl Pat {}
|
2018-08-26 09:09:28 +00:00
|
|
|
|
2018-08-30 17:03:18 +00:00
|
|
|
// Path
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct Path {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-30 17:03:18 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for Path {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for Path {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-30 17:03:18 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
PATH => Some(Path::from_repr(syntax.into_repr())),
|
2018-08-30 17:03:18 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<Path> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl Path {
|
|
|
|
pub fn segment(&self) -> Option<&PathSegment> {
|
2018-08-30 17:37:33 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2018-10-24 15:37:25 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn qualifier(&self) -> Option<&Path> {
|
2018-10-24 15:37:25 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2018-08-30 17:37:33 +00:00
|
|
|
}
|
2018-08-30 17:03:18 +00:00
|
|
|
|
2018-08-25 10:42:40 +00:00
|
|
|
// PathExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct PathExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for PathExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for PathExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
PATH_EXPR => Some(PathExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<PathExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-25 10:42:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl PathExpr {
|
|
|
|
pub fn path(&self) -> Option<&Path> {
|
2018-11-06 18:52:00 +00:00
|
|
|
super::child_opt(self)
|
2018-10-31 07:27:53 +00:00
|
|
|
}
|
|
|
|
}
|
2018-11-01 10:41:04 +00:00
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
// PathPat
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct PathPat {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for PathPat {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for PathPat {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-26 09:09:28 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
PATH_PAT => Some(PathPat::from_repr(syntax.into_repr())),
|
2018-08-26 09:09:28 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<PathPat> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-26 09:09:28 +00:00
|
|
|
}
|
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2019-01-15 14:24:04 +00:00
|
|
|
impl PathPat {
|
|
|
|
pub fn path(&self) -> Option<&Path> {
|
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// PathSegment
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct PathSegment {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for PathSegment {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for PathSegment {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-30 17:37:33 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
PATH_SEGMENT => Some(PathSegment::from_repr(syntax.into_repr())),
|
2018-08-30 17:37:33 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<PathSegment> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-30 17:37:33 +00:00
|
|
|
}
|
|
|
|
|
2018-10-31 07:27:53 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl PathSegment {
|
|
|
|
pub fn name_ref(&self) -> Option<&NameRef> {
|
2018-11-06 18:52:00 +00:00
|
|
|
super::child_opt(self)
|
2018-10-31 07:27:53 +00:00
|
|
|
}
|
|
|
|
}
|
2018-11-01 10:41:04 +00:00
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
// PathType
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct PathType {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-14 09:38:20 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for PathType {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for PathType {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-14 09:38:20 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
PATH_TYPE => Some(PathType::from_repr(syntax.into_repr())),
|
2018-08-14 09:38:20 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<PathType> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl PathType {
|
|
|
|
pub fn path(&self) -> Option<&Path> {
|
2018-12-22 21:17:55 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// PlaceholderPat
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct PlaceholderPat {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-26 09:09:28 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for PlaceholderPat {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for PlaceholderPat {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-26 09:09:28 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
PLACEHOLDER_PAT => Some(PlaceholderPat::from_repr(syntax.into_repr())),
|
2018-08-26 09:09:28 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<PlaceholderPat> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl PlaceholderPat {}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// PlaceholderType
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct PlaceholderType {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for PlaceholderType {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for PlaceholderType {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-14 09:38:20 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
PLACEHOLDER_TYPE => Some(PlaceholderType::from_repr(syntax.into_repr())),
|
2018-08-14 09:38:20 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<PlaceholderType> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-14 09:38:20 +00:00
|
|
|
}
|
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl PlaceholderType {}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// PointerType
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct PointerType {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for PointerType {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for PointerType {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-14 09:38:20 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
POINTER_TYPE => Some(PointerType::from_repr(syntax.into_repr())),
|
2018-08-14 09:38:20 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<PointerType> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-14 09:38:20 +00:00
|
|
|
}
|
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl PointerType {
|
|
|
|
pub fn type_ref(&self) -> Option<&TypeRef> {
|
2018-12-25 16:17:39 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2018-12-25 12:01:47 +00:00
|
|
|
// PosField
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct PosField {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-12-25 12:01:47 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for PosField {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-12-25 12:01:47 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for PosField {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-12-25 12:01:47 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
POS_FIELD => Some(PosField::from_repr(syntax.into_repr())),
|
2018-12-25 12:01:47 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<PosField> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-12-25 12:01:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ast::VisibilityOwner for PosField {}
|
|
|
|
impl ast::AttrsOwner for PosField {}
|
|
|
|
impl PosField {
|
|
|
|
pub fn type_ref(&self) -> Option<&TypeRef> {
|
2018-12-25 12:01:47 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// PosFieldList
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct PosFieldList {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-12-25 12:01:47 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for PosFieldList {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-12-25 12:01:47 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for PosFieldList {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-12-25 12:01:47 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
POS_FIELD_LIST => Some(PosFieldList::from_repr(syntax.into_repr())),
|
2018-12-25 12:01:47 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<PosFieldList> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-12-25 12:01:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl PosFieldList {
|
|
|
|
pub fn fields(&self) -> impl Iterator<Item = &PosField> {
|
2018-12-25 12:01:47 +00:00
|
|
|
super::children(self)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
// PrefixExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct PrefixExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-25 10:42:40 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for PrefixExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for PrefixExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
PREFIX_EXPR => Some(PrefixExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<PrefixExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl PrefixExpr {
|
|
|
|
pub fn expr(&self) -> Option<&Expr> {
|
2018-12-20 20:56:28 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// RangeExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct RangeExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-25 10:42:40 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for RangeExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for RangeExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
RANGE_EXPR => Some(RangeExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<RangeExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl RangeExpr {}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// RangePat
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct RangePat {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-26 09:09:28 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for RangePat {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for RangePat {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-26 09:09:28 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
RANGE_PAT => Some(RangePat::from_repr(syntax.into_repr())),
|
2018-08-26 09:09:28 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<RangePat> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-26 09:09:28 +00:00
|
|
|
}
|
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl RangePat {}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2019-01-14 19:56:14 +00:00
|
|
|
// RawByteString
|
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct RawByteString {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
|
|
|
}
|
|
|
|
unsafe impl TransparentNewType for RawByteString {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
|
|
|
}
|
|
|
|
|
|
|
|
impl AstNode for RawByteString {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
|
|
|
match syntax.kind() {
|
|
|
|
RAW_BYTE_STRING => Some(RawByteString::from_repr(syntax.into_repr())),
|
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
|
|
|
fn to_owned(&self) -> TreeArc<RawByteString> { TreeArc::cast(self.syntax.to_owned()) }
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
impl ast::AstToken for RawByteString {}
|
|
|
|
impl RawByteString {}
|
|
|
|
|
|
|
|
// RawString
|
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct RawString {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
|
|
|
}
|
|
|
|
unsafe impl TransparentNewType for RawString {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
|
|
|
}
|
|
|
|
|
|
|
|
impl AstNode for RawString {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
|
|
|
match syntax.kind() {
|
|
|
|
RAW_STRING => Some(RawString::from_repr(syntax.into_repr())),
|
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
|
|
|
fn to_owned(&self) -> TreeArc<RawString> { TreeArc::cast(self.syntax.to_owned()) }
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
impl ast::AstToken for RawString {}
|
|
|
|
impl RawString {}
|
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
// RefExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct RefExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for RefExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for RefExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
REF_EXPR => Some(RefExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<RefExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl RefExpr {
|
|
|
|
pub fn expr(&self) -> Option<&Expr> {
|
2018-12-20 20:56:28 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// RefPat
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct RefPat {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-26 09:09:28 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for RefPat {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for RefPat {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-26 09:09:28 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
REF_PAT => Some(RefPat::from_repr(syntax.into_repr())),
|
2018-08-26 09:09:28 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<RefPat> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-26 09:09:28 +00:00
|
|
|
}
|
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2019-01-13 10:34:57 +00:00
|
|
|
impl RefPat {
|
|
|
|
pub fn pat(&self) -> Option<&Pat> {
|
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// ReferenceType
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct ReferenceType {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-14 09:38:20 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for ReferenceType {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for ReferenceType {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-14 09:38:20 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
REFERENCE_TYPE => Some(ReferenceType::from_repr(syntax.into_repr())),
|
2018-08-14 09:38:20 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<ReferenceType> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ReferenceType {
|
|
|
|
pub fn type_ref(&self) -> Option<&TypeRef> {
|
2018-12-25 16:17:39 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// RetType
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct RetType {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for RetType {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for RetType {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-28 18:11:17 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
RET_TYPE => Some(RetType::from_repr(syntax.into_repr())),
|
2018-08-28 18:11:17 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<RetType> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl RetType {
|
|
|
|
pub fn type_ref(&self) -> Option<&TypeRef> {
|
2018-12-23 16:13:11 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// ReturnExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct ReturnExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for ReturnExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for ReturnExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
RETURN_EXPR => Some(ReturnExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<ReturnExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-25 10:42:40 +00:00
|
|
|
}
|
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ReturnExpr {
|
|
|
|
pub fn expr(&self) -> Option<&Expr> {
|
2018-12-20 20:56:28 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2018-12-29 20:32:07 +00:00
|
|
|
// SelfKw
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct SelfKw {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-12-29 20:32:07 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for SelfKw {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-12-29 20:32:07 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for SelfKw {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-12-29 20:32:07 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
SELF_KW => Some(SelfKw::from_repr(syntax.into_repr())),
|
2018-12-29 20:32:07 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<SelfKw> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-12-29 20:32:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl SelfKw {}
|
2018-12-29 20:32:07 +00:00
|
|
|
|
2018-08-31 13:30:42 +00:00
|
|
|
// SelfParam
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct SelfParam {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for SelfParam {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for SelfParam {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-31 13:30:42 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
SELF_PARAM => Some(SelfParam::from_repr(syntax.into_repr())),
|
2018-08-31 13:30:42 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<SelfParam> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl SelfParam {
|
|
|
|
pub fn type_ref(&self) -> Option<&TypeRef> {
|
2018-12-29 20:32:07 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn self_kw(&self) -> Option<&SelfKw> {
|
2018-12-29 20:32:07 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// SlicePat
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct SlicePat {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-26 09:09:28 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for SlicePat {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for SlicePat {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-26 09:09:28 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
SLICE_PAT => Some(SlicePat::from_repr(syntax.into_repr())),
|
2018-08-26 09:09:28 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<SlicePat> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl SlicePat {}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// SliceType
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct SliceType {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-14 09:38:20 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for SliceType {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for SliceType {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-14 09:38:20 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
SLICE_TYPE => Some(SliceType::from_repr(syntax.into_repr())),
|
2018-08-14 09:38:20 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<SliceType> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-14 09:38:20 +00:00
|
|
|
}
|
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl SliceType {
|
|
|
|
pub fn type_ref(&self) -> Option<&TypeRef> {
|
2018-12-25 20:14:13 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-08-14 09:38:20 +00:00
|
|
|
|
2018-11-07 15:38:43 +00:00
|
|
|
// SourceFile
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct SourceFile {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-07 15:38:43 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for SourceFile {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-07 15:38:43 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for SourceFile {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-11-07 15:38:43 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
SOURCE_FILE => Some(SourceFile::from_repr(syntax.into_repr())),
|
2018-11-07 15:38:43 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<SourceFile> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-07 15:38:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ast::ModuleItemOwner for SourceFile {}
|
|
|
|
impl ast::FnDefOwner for SourceFile {}
|
|
|
|
impl SourceFile {
|
|
|
|
pub fn modules(&self) -> impl Iterator<Item = &Module> {
|
2018-11-07 15:38:43 +00:00
|
|
|
super::children(self)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-13 15:36:16 +00:00
|
|
|
// StaticDef
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct StaticDef {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for StaticDef {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for StaticDef {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-11 08:03:22 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
STATIC_DEF => Some(StaticDef::from_repr(syntax.into_repr())),
|
2018-08-11 08:03:22 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<StaticDef> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ast::VisibilityOwner for StaticDef {}
|
|
|
|
impl ast::NameOwner for StaticDef {}
|
|
|
|
impl ast::TypeParamsOwner for StaticDef {}
|
|
|
|
impl ast::AttrsOwner for StaticDef {}
|
|
|
|
impl ast::DocCommentsOwner for StaticDef {}
|
|
|
|
impl StaticDef {}
|
2018-08-11 08:03:22 +00:00
|
|
|
|
2018-08-27 07:12:28 +00:00
|
|
|
// Stmt
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct Stmt {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
|
|
|
}
|
|
|
|
unsafe impl TransparentNewType for Stmt {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
|
|
|
}
|
|
|
|
|
2018-11-06 19:47:38 +00:00
|
|
|
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
|
2019-01-07 13:16:02 +00:00
|
|
|
pub enum StmtKind<'a> {
|
|
|
|
ExprStmt(&'a ExprStmt),
|
|
|
|
LetStmt(&'a LetStmt),
|
2018-08-27 07:12:28 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for Stmt {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-27 07:12:28 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
| EXPR_STMT
|
|
|
|
| LET_STMT => Some(Stmt::from_repr(syntax.into_repr())),
|
2018-08-27 07:12:28 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<Stmt> { TreeArc::cast(self.syntax.to_owned()) }
|
2019-01-07 13:16:02 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
impl Stmt {
|
|
|
|
pub fn kind(&self) -> StmtKind {
|
|
|
|
match self.syntax.kind() {
|
|
|
|
EXPR_STMT => StmtKind::ExprStmt(ExprStmt::cast(&self.syntax).unwrap()),
|
|
|
|
LET_STMT => StmtKind::LetStmt(LetStmt::cast(&self.syntax).unwrap()),
|
|
|
|
_ => unreachable!(),
|
2018-08-27 07:12:28 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl Stmt {}
|
2018-08-27 07:12:28 +00:00
|
|
|
|
2018-11-08 14:42:00 +00:00
|
|
|
// String
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct String {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-08 14:42:00 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for String {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-08 14:42:00 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for String {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-11-08 14:42:00 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
STRING => Some(String::from_repr(syntax.into_repr())),
|
2018-11-08 14:42:00 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<String> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-08 14:42:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-08 09:23:10 +00:00
|
|
|
impl ast::AstToken for String {}
|
2019-01-07 13:16:02 +00:00
|
|
|
impl String {}
|
2018-11-08 14:42:00 +00:00
|
|
|
|
2018-08-13 15:36:16 +00:00
|
|
|
// StructDef
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct StructDef {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for StructDef {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for StructDef {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-11 07:56:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
STRUCT_DEF => Some(StructDef::from_repr(syntax.into_repr())),
|
2018-08-11 07:56:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<StructDef> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-11 07:56:40 +00:00
|
|
|
}
|
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ast::VisibilityOwner for StructDef {}
|
|
|
|
impl ast::NameOwner for StructDef {}
|
|
|
|
impl ast::TypeParamsOwner for StructDef {}
|
|
|
|
impl ast::AttrsOwner for StructDef {}
|
|
|
|
impl ast::DocCommentsOwner for StructDef {}
|
|
|
|
impl StructDef {}
|
2018-08-11 07:56:40 +00:00
|
|
|
|
2018-08-25 10:42:40 +00:00
|
|
|
// StructLit
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct StructLit {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for StructLit {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for StructLit {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
STRUCT_LIT => Some(StructLit::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<StructLit> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl StructLit {
|
|
|
|
pub fn path(&self) -> Option<&Path> {
|
2018-12-24 20:00:14 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn named_field_list(&self) -> Option<&NamedFieldList> {
|
2018-12-24 20:00:14 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2019-01-05 15:32:07 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn spread(&self) -> Option<&Expr> {
|
2019-01-05 15:32:07 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2018-12-24 20:00:14 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// StructPat
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct StructPat {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for StructPat {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for StructPat {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-26 09:09:28 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
STRUCT_PAT => Some(StructPat::from_repr(syntax.into_repr())),
|
2018-08-26 09:09:28 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<StructPat> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-16 18:35:27 +00:00
|
|
|
impl StructPat {
|
|
|
|
pub fn field_pat_list(&self) -> Option<&FieldPatList> {
|
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn path(&self) -> Option<&Path> {
|
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// TokenTree
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct TokenTree {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-16 09:51:40 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for TokenTree {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for TokenTree {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-16 09:51:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
TOKEN_TREE => Some(TokenTree::from_repr(syntax.into_repr())),
|
2018-08-16 09:51:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<TokenTree> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl TokenTree {}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// TraitDef
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct TraitDef {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-11 08:03:22 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for TraitDef {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for TraitDef {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-11 08:03:22 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
TRAIT_DEF => Some(TraitDef::from_repr(syntax.into_repr())),
|
2018-08-11 08:03:22 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<TraitDef> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ast::VisibilityOwner for TraitDef {}
|
|
|
|
impl ast::NameOwner for TraitDef {}
|
|
|
|
impl ast::AttrsOwner for TraitDef {}
|
|
|
|
impl ast::DocCommentsOwner for TraitDef {}
|
|
|
|
impl TraitDef {}
|
2018-08-11 08:03:22 +00:00
|
|
|
|
2019-01-14 18:30:21 +00:00
|
|
|
// TrueKw
|
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct TrueKw {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
|
|
|
}
|
|
|
|
unsafe impl TransparentNewType for TrueKw {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
|
|
|
}
|
|
|
|
|
|
|
|
impl AstNode for TrueKw {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
|
|
|
match syntax.kind() {
|
|
|
|
TRUE_KW => Some(TrueKw::from_repr(syntax.into_repr())),
|
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
|
|
|
fn to_owned(&self) -> TreeArc<TrueKw> { TreeArc::cast(self.syntax.to_owned()) }
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
impl ast::AstToken for TrueKw {}
|
|
|
|
impl TrueKw {}
|
|
|
|
|
2018-08-25 10:42:40 +00:00
|
|
|
// TryExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct TryExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for TryExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for TryExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
TRY_EXPR => Some(TryExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<TryExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-25 10:42:40 +00:00
|
|
|
}
|
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl TryExpr {
|
|
|
|
pub fn expr(&self) -> Option<&Expr> {
|
2018-12-20 20:56:28 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// TupleExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct TupleExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for TupleExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for TupleExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
TUPLE_EXPR => Some(TupleExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<TupleExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-13 11:52:25 +00:00
|
|
|
impl TupleExpr {
|
|
|
|
pub fn exprs(&self) -> impl Iterator<Item = &Expr> {
|
|
|
|
super::children(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// TuplePat
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct TuplePat {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-26 09:09:28 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for TuplePat {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for TuplePat {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-26 09:09:28 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
TUPLE_PAT => Some(TuplePat::from_repr(syntax.into_repr())),
|
2018-08-26 09:09:28 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<TuplePat> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-15 14:24:04 +00:00
|
|
|
impl TuplePat {
|
|
|
|
pub fn args(&self) -> impl Iterator<Item = &Pat> {
|
|
|
|
super::children(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// TupleStructPat
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct TupleStructPat {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-26 09:09:28 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for TupleStructPat {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for TupleStructPat {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-26 09:09:28 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
TUPLE_STRUCT_PAT => Some(TupleStructPat::from_repr(syntax.into_repr())),
|
2018-08-26 09:09:28 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<TupleStructPat> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-26 09:09:28 +00:00
|
|
|
}
|
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl TupleStructPat {
|
|
|
|
pub fn args(&self) -> impl Iterator<Item = &Pat> {
|
2019-01-05 21:37:59 +00:00
|
|
|
super::children(self)
|
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn path(&self) -> Option<&Path> {
|
2019-01-05 21:37:59 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// TupleType
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct TupleType {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-14 09:38:20 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for TupleType {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for TupleType {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-14 09:38:20 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
TUPLE_TYPE => Some(TupleType::from_repr(syntax.into_repr())),
|
2018-08-14 09:38:20 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<TupleType> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl TupleType {
|
|
|
|
pub fn fields(&self) -> impl Iterator<Item = &TypeRef> {
|
2018-12-25 20:14:13 +00:00
|
|
|
super::children(self)
|
|
|
|
}
|
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// TypeDef
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct TypeDef {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for TypeDef {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for TypeDef {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-11 13:20:37 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
TYPE_DEF => Some(TypeDef::from_repr(syntax.into_repr())),
|
2018-08-11 13:20:37 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<TypeDef> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ast::VisibilityOwner for TypeDef {}
|
|
|
|
impl ast::NameOwner for TypeDef {}
|
|
|
|
impl ast::TypeParamsOwner for TypeDef {}
|
|
|
|
impl ast::AttrsOwner for TypeDef {}
|
|
|
|
impl ast::DocCommentsOwner for TypeDef {}
|
|
|
|
impl TypeDef {}
|
2018-08-11 13:20:37 +00:00
|
|
|
|
2018-08-22 16:02:37 +00:00
|
|
|
// TypeParam
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct TypeParam {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for TypeParam {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for TypeParam {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-22 16:02:37 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
TYPE_PARAM => Some(TypeParam::from_repr(syntax.into_repr())),
|
2018-08-22 16:02:37 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<TypeParam> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-22 16:02:37 +00:00
|
|
|
}
|
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ast::NameOwner for TypeParam {}
|
|
|
|
impl TypeParam {}
|
2018-08-22 16:02:37 +00:00
|
|
|
|
2018-08-22 13:46:42 +00:00
|
|
|
// TypeParamList
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct TypeParamList {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for TypeParamList {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for TypeParamList {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-22 13:46:42 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
TYPE_PARAM_LIST => Some(TypeParamList::from_repr(syntax.into_repr())),
|
2018-08-22 13:46:42 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<TypeParamList> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-22 13:46:42 +00:00
|
|
|
}
|
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl TypeParamList {
|
|
|
|
pub fn type_params(&self) -> impl Iterator<Item = &TypeParam> {
|
2018-08-22 16:02:37 +00:00
|
|
|
super::children(self)
|
|
|
|
}
|
2018-08-28 20:59:57 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn lifetime_params(&self) -> impl Iterator<Item = &LifetimeParam> {
|
2018-08-28 20:59:57 +00:00
|
|
|
super::children(self)
|
|
|
|
}
|
2018-08-22 16:02:37 +00:00
|
|
|
}
|
2018-08-22 13:46:42 +00:00
|
|
|
|
2018-08-14 09:38:20 +00:00
|
|
|
// TypeRef
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct TypeRef {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
|
|
|
}
|
|
|
|
unsafe impl TransparentNewType for TypeRef {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-08-14 09:38:20 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, Clone, Copy, PartialEq, Eq)]
|
|
|
|
pub enum TypeRefKind<'a> {
|
|
|
|
ParenType(&'a ParenType),
|
|
|
|
TupleType(&'a TupleType),
|
|
|
|
NeverType(&'a NeverType),
|
|
|
|
PathType(&'a PathType),
|
|
|
|
PointerType(&'a PointerType),
|
|
|
|
ArrayType(&'a ArrayType),
|
|
|
|
SliceType(&'a SliceType),
|
|
|
|
ReferenceType(&'a ReferenceType),
|
|
|
|
PlaceholderType(&'a PlaceholderType),
|
|
|
|
FnPointerType(&'a FnPointerType),
|
|
|
|
ForType(&'a ForType),
|
|
|
|
ImplTraitType(&'a ImplTraitType),
|
|
|
|
DynTraitType(&'a DynTraitType),
|
|
|
|
}
|
|
|
|
|
|
|
|
impl AstNode for TypeRef {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
|
|
|
match syntax.kind() {
|
|
|
|
| PAREN_TYPE
|
|
|
|
| TUPLE_TYPE
|
|
|
|
| NEVER_TYPE
|
|
|
|
| PATH_TYPE
|
|
|
|
| POINTER_TYPE
|
|
|
|
| ARRAY_TYPE
|
|
|
|
| SLICE_TYPE
|
|
|
|
| REFERENCE_TYPE
|
|
|
|
| PLACEHOLDER_TYPE
|
|
|
|
| FN_POINTER_TYPE
|
|
|
|
| FOR_TYPE
|
|
|
|
| IMPL_TRAIT_TYPE
|
|
|
|
| DYN_TRAIT_TYPE => Some(TypeRef::from_repr(syntax.into_repr())),
|
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<TypeRef> { TreeArc::cast(self.syntax.to_owned()) }
|
2019-01-07 13:16:02 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
impl TypeRef {
|
|
|
|
pub fn kind(&self) -> TypeRefKind {
|
|
|
|
match self.syntax.kind() {
|
|
|
|
PAREN_TYPE => TypeRefKind::ParenType(ParenType::cast(&self.syntax).unwrap()),
|
|
|
|
TUPLE_TYPE => TypeRefKind::TupleType(TupleType::cast(&self.syntax).unwrap()),
|
|
|
|
NEVER_TYPE => TypeRefKind::NeverType(NeverType::cast(&self.syntax).unwrap()),
|
|
|
|
PATH_TYPE => TypeRefKind::PathType(PathType::cast(&self.syntax).unwrap()),
|
|
|
|
POINTER_TYPE => TypeRefKind::PointerType(PointerType::cast(&self.syntax).unwrap()),
|
|
|
|
ARRAY_TYPE => TypeRefKind::ArrayType(ArrayType::cast(&self.syntax).unwrap()),
|
|
|
|
SLICE_TYPE => TypeRefKind::SliceType(SliceType::cast(&self.syntax).unwrap()),
|
|
|
|
REFERENCE_TYPE => TypeRefKind::ReferenceType(ReferenceType::cast(&self.syntax).unwrap()),
|
|
|
|
PLACEHOLDER_TYPE => TypeRefKind::PlaceholderType(PlaceholderType::cast(&self.syntax).unwrap()),
|
|
|
|
FN_POINTER_TYPE => TypeRefKind::FnPointerType(FnPointerType::cast(&self.syntax).unwrap()),
|
|
|
|
FOR_TYPE => TypeRefKind::ForType(ForType::cast(&self.syntax).unwrap()),
|
|
|
|
IMPL_TRAIT_TYPE => TypeRefKind::ImplTraitType(ImplTraitType::cast(&self.syntax).unwrap()),
|
|
|
|
DYN_TRAIT_TYPE => TypeRefKind::DynTraitType(DynTraitType::cast(&self.syntax).unwrap()),
|
|
|
|
_ => unreachable!(),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl TypeRef {}
|
2018-08-14 09:38:20 +00:00
|
|
|
|
2018-08-28 08:12:42 +00:00
|
|
|
// UseItem
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct UseItem {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-28 08:12:42 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for UseItem {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for UseItem {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-28 08:12:42 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
USE_ITEM => Some(UseItem::from_repr(syntax.into_repr())),
|
2018-08-28 08:12:42 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<UseItem> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-30 17:37:33 +00:00
|
|
|
}
|
|
|
|
|
2018-10-31 07:27:53 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl UseItem {
|
|
|
|
pub fn use_tree(&self) -> Option<&UseTree> {
|
2018-11-06 18:52:00 +00:00
|
|
|
super::child_opt(self)
|
2018-10-31 07:27:53 +00:00
|
|
|
}
|
|
|
|
}
|
2018-11-01 10:41:04 +00:00
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
// UseTree
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct UseTree {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-08-30 17:37:33 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for UseTree {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for UseTree {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-30 17:37:33 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
USE_TREE => Some(UseTree::from_repr(syntax.into_repr())),
|
2018-08-30 17:37:33 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<UseTree> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl UseTree {
|
|
|
|
pub fn path(&self) -> Option<&Path> {
|
2018-08-30 17:37:33 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
2018-10-10 15:26:01 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
pub fn use_tree_list(&self) -> Option<&UseTreeList> {
|
2018-08-30 17:37:33 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// UseTreeList
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct UseTreeList {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for UseTreeList {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for UseTreeList {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-30 17:37:33 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
USE_TREE_LIST => Some(UseTreeList::from_repr(syntax.into_repr())),
|
2018-08-30 17:37:33 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<UseTreeList> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-08-30 17:37:33 +00:00
|
|
|
}
|
2018-08-28 08:12:42 +00:00
|
|
|
|
2018-10-31 07:27:53 +00:00
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl UseTreeList {
|
|
|
|
pub fn use_trees(&self) -> impl Iterator<Item = &UseTree> {
|
2018-11-06 18:52:00 +00:00
|
|
|
super::children(self)
|
2018-10-31 07:27:53 +00:00
|
|
|
}
|
|
|
|
}
|
2018-11-01 10:41:04 +00:00
|
|
|
|
2019-01-03 10:47:28 +00:00
|
|
|
// Visibility
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct Visibility {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2019-01-03 10:47:28 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for Visibility {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2019-01-03 10:47:28 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for Visibility {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2019-01-03 10:47:28 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
VISIBILITY => Some(Visibility::from_repr(syntax.into_repr())),
|
2019-01-03 10:47:28 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<Visibility> { TreeArc::cast(self.syntax.to_owned()) }
|
2019-01-03 10:47:28 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl Visibility {}
|
2019-01-03 10:47:28 +00:00
|
|
|
|
2018-11-06 18:52:00 +00:00
|
|
|
// WhereClause
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct WhereClause {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for WhereClause {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for WhereClause {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-22 08:56:36 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
WHERE_CLAUSE => Some(WhereClause::from_repr(syntax.into_repr())),
|
2018-08-22 08:56:36 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<WhereClause> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-01 10:41:04 +00:00
|
|
|
}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl WhereClause {}
|
2018-11-06 18:52:00 +00:00
|
|
|
|
|
|
|
// WhileExpr
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct WhileExpr {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for WhileExpr {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for WhileExpr {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-08-25 10:42:40 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
WHILE_EXPR => Some(WhileExpr::from_repr(syntax.into_repr())),
|
2018-08-25 10:42:40 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<WhileExpr> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl ast::LoopBodyOwner for WhileExpr {}
|
|
|
|
impl WhileExpr {
|
|
|
|
pub fn condition(&self) -> Option<&Condition> {
|
2018-08-27 09:22:09 +00:00
|
|
|
super::child_opt(self)
|
|
|
|
}
|
|
|
|
}
|
2018-08-25 10:42:40 +00:00
|
|
|
|
2018-10-12 17:20:58 +00:00
|
|
|
// Whitespace
|
2019-01-07 13:16:02 +00:00
|
|
|
#[derive(Debug, PartialEq, Eq, Hash)]
|
|
|
|
#[repr(transparent)]
|
|
|
|
pub struct Whitespace {
|
|
|
|
pub(crate) syntax: SyntaxNode,
|
2018-10-12 17:20:58 +00:00
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
unsafe impl TransparentNewType for Whitespace {
|
|
|
|
type Repr = rowan::SyntaxNode<RaTypes>;
|
2018-11-06 19:47:38 +00:00
|
|
|
}
|
|
|
|
|
2019-01-07 13:16:02 +00:00
|
|
|
impl AstNode for Whitespace {
|
|
|
|
fn cast(syntax: &SyntaxNode) -> Option<&Self> {
|
2018-10-12 17:20:58 +00:00
|
|
|
match syntax.kind() {
|
2019-01-07 13:16:02 +00:00
|
|
|
WHITESPACE => Some(Whitespace::from_repr(syntax.into_repr())),
|
2018-10-12 17:20:58 +00:00
|
|
|
_ => None,
|
|
|
|
}
|
|
|
|
}
|
2019-01-07 13:16:02 +00:00
|
|
|
fn syntax(&self) -> &SyntaxNode { &self.syntax }
|
2019-01-11 16:59:06 +00:00
|
|
|
fn to_owned(&self) -> TreeArc<Whitespace> { TreeArc::cast(self.syntax.to_owned()) }
|
2018-11-06 18:52:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2019-01-08 09:23:10 +00:00
|
|
|
impl ast::AstToken for Whitespace {}
|
2019-01-07 13:16:02 +00:00
|
|
|
impl Whitespace {}
|
2018-10-12 17:20:58 +00:00
|
|
|
|