From 8eaf7952ae4ba510d448a7e310a3e2dcfd09f6d3 Mon Sep 17 00:00:00 2001 From: Aleksey Kladov Date: Tue, 6 Nov 2018 22:47:38 +0300 Subject: ra_syntax::File is just RootNode --- crates/ra_syntax/src/ast/generated.rs | 1142 +++++++++++++++++++++++----- crates/ra_syntax/src/ast/generated.rs.tera | 16 +- 2 files changed, 961 insertions(+), 197 deletions(-) (limited to 'crates/ra_syntax/src/ast') diff --git a/crates/ra_syntax/src/ast/generated.rs b/crates/ra_syntax/src/ast/generated.rs index 420d9090c..3878c99a8 100644 --- a/crates/ra_syntax/src/ast/generated.rs +++ b/crates/ra_syntax/src/ast/generated.rs @@ -9,6 +9,8 @@ #![cfg_attr(rustfmt, rustfmt_skip)] +use std::hash::{Hash, Hasher}; + use crate::{ ast, SyntaxNode, SyntaxNodeRef, AstNode, @@ -17,12 +19,20 @@ use crate::{ }; // ArgList -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct ArgListNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type ArgList<'a> = ArgListNode>; +impl, R2: TreeRoot> PartialEq> for ArgListNode { + fn eq(&self, other: &ArgListNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for ArgListNode {} +impl> Hash for ArgListNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for ArgList<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -50,12 +60,20 @@ impl<'a> ArgList<'a> { } // ArrayExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct ArrayExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type ArrayExpr<'a> = ArrayExprNode>; +impl, R2: TreeRoot> PartialEq> for ArrayExprNode { + fn eq(&self, other: &ArrayExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for ArrayExprNode {} +impl> Hash for ArrayExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for ArrayExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -79,12 +97,20 @@ impl> ArrayExprNode { impl<'a> ArrayExpr<'a> {} // ArrayType -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct ArrayTypeNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type ArrayType<'a> = ArrayTypeNode>; +impl, R2: TreeRoot> PartialEq> for ArrayTypeNode { + fn eq(&self, other: &ArrayTypeNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for ArrayTypeNode {} +impl> Hash for ArrayTypeNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for ArrayType<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -108,12 +134,20 @@ impl> ArrayTypeNode { impl<'a> ArrayType<'a> {} // Attr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct AttrNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type Attr<'a> = AttrNode>; +impl, R2: TreeRoot> PartialEq> for AttrNode { + fn eq(&self, other: &AttrNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for AttrNode {} +impl> Hash for AttrNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for Attr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -141,12 +175,20 @@ impl<'a> Attr<'a> { } // BinExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct BinExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type BinExpr<'a> = BinExprNode>; +impl, R2: TreeRoot> PartialEq> for BinExprNode { + fn eq(&self, other: &BinExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for BinExprNode {} +impl> Hash for BinExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for BinExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -170,12 +212,20 @@ impl> BinExprNode { impl<'a> BinExpr<'a> {} // BindPat -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct BindPatNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type BindPat<'a> = BindPatNode>; +impl, R2: TreeRoot> PartialEq> for BindPatNode { + fn eq(&self, other: &BindPatNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for BindPatNode {} +impl> Hash for BindPatNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for BindPat<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -200,12 +250,20 @@ impl<'a> ast::NameOwner<'a> for BindPat<'a> {} impl<'a> BindPat<'a> {} // Block -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct BlockNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type Block<'a> = BlockNode>; +impl, R2: TreeRoot> PartialEq> for BlockNode { + fn eq(&self, other: &BlockNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for BlockNode {} +impl> Hash for BlockNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for Block<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -237,12 +295,20 @@ impl<'a> Block<'a> { } // BlockExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct BlockExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type BlockExpr<'a> = BlockExprNode>; +impl, R2: TreeRoot> PartialEq> for BlockExprNode { + fn eq(&self, other: &BlockExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for BlockExprNode {} +impl> Hash for BlockExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for BlockExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -270,12 +336,20 @@ impl<'a> BlockExpr<'a> { } // BreakExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct BreakExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type BreakExpr<'a> = BreakExprNode>; +impl, R2: TreeRoot> PartialEq> for BreakExprNode { + fn eq(&self, other: &BreakExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for BreakExprNode {} +impl> Hash for BreakExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for BreakExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -299,12 +373,20 @@ impl> BreakExprNode { impl<'a> BreakExpr<'a> {} // CallExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct CallExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type CallExpr<'a> = CallExprNode>; +impl, R2: TreeRoot> PartialEq> for CallExprNode { + fn eq(&self, other: &CallExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for CallExprNode {} +impl> Hash for CallExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for CallExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -333,12 +415,20 @@ impl<'a> CallExpr<'a> { } // CastExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct CastExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type CastExpr<'a> = CastExprNode>; +impl, R2: TreeRoot> PartialEq> for CastExprNode { + fn eq(&self, other: &CastExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for CastExprNode {} +impl> Hash for CastExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for CastExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -362,12 +452,20 @@ impl> CastExprNode { impl<'a> CastExpr<'a> {} // Char -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct CharNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type Char<'a> = CharNode>; +impl, R2: TreeRoot> PartialEq> for CharNode { + fn eq(&self, other: &CharNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for CharNode {} +impl> Hash for CharNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for Char<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -391,12 +489,20 @@ impl> CharNode { impl<'a> Char<'a> {} // Comment -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct CommentNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type Comment<'a> = CommentNode>; +impl, R2: TreeRoot> PartialEq> for CommentNode { + fn eq(&self, other: &CommentNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for CommentNode {} +impl> Hash for CommentNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for Comment<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -420,12 +526,20 @@ impl> CommentNode { impl<'a> Comment<'a> {} // Condition -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct ConditionNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type Condition<'a> = ConditionNode>; +impl, R2: TreeRoot> PartialEq> for ConditionNode { + fn eq(&self, other: &ConditionNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for ConditionNode {} +impl> Hash for ConditionNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for Condition<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -457,12 +571,20 @@ impl<'a> Condition<'a> { } // ConstDef -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct ConstDefNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type ConstDef<'a> = ConstDefNode>; +impl, R2: TreeRoot> PartialEq> for ConstDefNode { + fn eq(&self, other: &ConstDefNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for ConstDefNode {} +impl> Hash for ConstDefNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for ConstDef<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -489,12 +611,20 @@ impl<'a> ast::AttrsOwner<'a> for ConstDef<'a> {} impl<'a> ConstDef<'a> {} // ContinueExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct ContinueExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type ContinueExpr<'a> = ContinueExprNode>; +impl, R2: TreeRoot> PartialEq> for ContinueExprNode { + fn eq(&self, other: &ContinueExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for ContinueExprNode {} +impl> Hash for ContinueExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for ContinueExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -518,12 +648,20 @@ impl> ContinueExprNode { impl<'a> ContinueExpr<'a> {} // DynTraitType -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct DynTraitTypeNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type DynTraitType<'a> = DynTraitTypeNode>; +impl, R2: TreeRoot> PartialEq> for DynTraitTypeNode { + fn eq(&self, other: &DynTraitTypeNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for DynTraitTypeNode {} +impl> Hash for DynTraitTypeNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for DynTraitType<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -547,12 +685,20 @@ impl> DynTraitTypeNode { impl<'a> DynTraitType<'a> {} // EnumDef -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct EnumDefNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type EnumDef<'a> = EnumDefNode>; +impl, R2: TreeRoot> PartialEq> for EnumDefNode { + fn eq(&self, other: &EnumDefNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for EnumDefNode {} +impl> Hash for EnumDefNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for EnumDef<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -579,7 +725,7 @@ impl<'a> ast::AttrsOwner<'a> for EnumDef<'a> {} impl<'a> EnumDef<'a> {} // Expr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy, PartialEq, Eq)] pub enum Expr<'a> { TupleExpr(TupleExpr<'a>), ArrayExpr(ArrayExpr<'a>), @@ -694,12 +840,20 @@ impl<'a> AstNode<'a> for Expr<'a> { impl<'a> Expr<'a> {} // ExprStmt -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct ExprStmtNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type ExprStmt<'a> = ExprStmtNode>; +impl, R2: TreeRoot> PartialEq> for ExprStmtNode { + fn eq(&self, other: &ExprStmtNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for ExprStmtNode {} +impl> Hash for ExprStmtNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for ExprStmt<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -727,12 +881,20 @@ impl<'a> ExprStmt<'a> { } // ExternCrateItem -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct ExternCrateItemNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type ExternCrateItem<'a> = ExternCrateItemNode>; +impl, R2: TreeRoot> PartialEq> for ExternCrateItemNode { + fn eq(&self, other: &ExternCrateItemNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for ExternCrateItemNode {} +impl> Hash for ExternCrateItemNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for ExternCrateItem<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -756,12 +918,20 @@ impl> ExternCrateItemNode { impl<'a> ExternCrateItem<'a> {} // FieldExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct FieldExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type FieldExpr<'a> = FieldExprNode>; +impl, R2: TreeRoot> PartialEq> for FieldExprNode { + fn eq(&self, other: &FieldExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for FieldExprNode {} +impl> Hash for FieldExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for FieldExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -785,12 +955,20 @@ impl> FieldExprNode { impl<'a> FieldExpr<'a> {} // FieldPatList -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct FieldPatListNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type FieldPatList<'a> = FieldPatListNode>; +impl, R2: TreeRoot> PartialEq> for FieldPatListNode { + fn eq(&self, other: &FieldPatListNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for FieldPatListNode {} +impl> Hash for FieldPatListNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for FieldPatList<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -814,12 +992,20 @@ impl> FieldPatListNode { impl<'a> FieldPatList<'a> {} // FnDef -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct FnDefNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type FnDef<'a> = FnDefNode>; +impl, R2: TreeRoot> PartialEq> for FnDefNode { + fn eq(&self, other: &FnDefNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for FnDefNode {} +impl> Hash for FnDefNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for FnDef<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -859,12 +1045,20 @@ impl<'a> FnDef<'a> { } // FnPointerType -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct FnPointerTypeNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type FnPointerType<'a> = FnPointerTypeNode>; +impl, R2: TreeRoot> PartialEq> for FnPointerTypeNode { + fn eq(&self, other: &FnPointerTypeNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for FnPointerTypeNode {} +impl> Hash for FnPointerTypeNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for FnPointerType<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -888,12 +1082,20 @@ impl> FnPointerTypeNode { impl<'a> FnPointerType<'a> {} // ForExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct ForExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type ForExpr<'a> = ForExprNode>; +impl, R2: TreeRoot> PartialEq> for ForExprNode { + fn eq(&self, other: &ForExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for ForExprNode {} +impl> Hash for ForExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for ForExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -926,12 +1128,20 @@ impl<'a> ForExpr<'a> { } // ForType -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct ForTypeNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type ForType<'a> = ForTypeNode>; +impl, R2: TreeRoot> PartialEq> for ForTypeNode { + fn eq(&self, other: &ForTypeNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for ForTypeNode {} +impl> Hash for ForTypeNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for ForType<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -955,12 +1165,20 @@ impl> ForTypeNode { impl<'a> ForType<'a> {} // IfExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct IfExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type IfExpr<'a> = IfExprNode>; +impl, R2: TreeRoot> PartialEq> for IfExprNode { + fn eq(&self, other: &IfExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for IfExprNode {} +impl> Hash for IfExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for IfExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -988,12 +1206,20 @@ impl<'a> IfExpr<'a> { } // ImplItem -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct ImplItemNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type ImplItem<'a> = ImplItemNode>; +impl, R2: TreeRoot> PartialEq> for ImplItemNode { + fn eq(&self, other: &ImplItemNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for ImplItemNode {} +impl> Hash for ImplItemNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for ImplItem<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1017,12 +1243,20 @@ impl> ImplItemNode { impl<'a> ImplItem<'a> {} // ImplTraitType -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct ImplTraitTypeNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type ImplTraitType<'a> = ImplTraitTypeNode>; +impl, R2: TreeRoot> PartialEq> for ImplTraitTypeNode { + fn eq(&self, other: &ImplTraitTypeNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for ImplTraitTypeNode {} +impl> Hash for ImplTraitTypeNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for ImplTraitType<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1046,12 +1280,20 @@ impl> ImplTraitTypeNode { impl<'a> ImplTraitType<'a> {} // IndexExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct IndexExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type IndexExpr<'a> = IndexExprNode>; +impl, R2: TreeRoot> PartialEq> for IndexExprNode { + fn eq(&self, other: &IndexExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for IndexExprNode {} +impl> Hash for IndexExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for IndexExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1075,12 +1317,20 @@ impl> IndexExprNode { impl<'a> IndexExpr<'a> {} // ItemList -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct ItemListNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type ItemList<'a> = ItemListNode>; +impl, R2: TreeRoot> PartialEq> for ItemListNode { + fn eq(&self, other: &ItemListNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for ItemListNode {} +impl> Hash for ItemListNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for ItemList<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1106,12 +1356,20 @@ impl<'a> ast::ModuleItemOwner<'a> for ItemList<'a> {} impl<'a> ItemList<'a> {} // Label -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct LabelNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type Label<'a> = LabelNode>; +impl, R2: TreeRoot> PartialEq> for LabelNode { + fn eq(&self, other: &LabelNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for LabelNode {} +impl> Hash for LabelNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for Label<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1135,12 +1393,20 @@ impl> LabelNode { impl<'a> Label<'a> {} // LambdaExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct LambdaExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type LambdaExpr<'a> = LambdaExprNode>; +impl, R2: TreeRoot> PartialEq> for LambdaExprNode { + fn eq(&self, other: &LambdaExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for LambdaExprNode {} +impl> Hash for LambdaExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for LambdaExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1172,12 +1438,20 @@ impl<'a> LambdaExpr<'a> { } // LetStmt -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct LetStmtNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type LetStmt<'a> = LetStmtNode>; +impl, R2: TreeRoot> PartialEq> for LetStmtNode { + fn eq(&self, other: &LetStmtNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for LetStmtNode {} +impl> Hash for LetStmtNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for LetStmt<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1209,12 +1483,20 @@ impl<'a> LetStmt<'a> { } // Lifetime -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct LifetimeNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type Lifetime<'a> = LifetimeNode>; +impl, R2: TreeRoot> PartialEq> for LifetimeNode { + fn eq(&self, other: &LifetimeNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for LifetimeNode {} +impl> Hash for LifetimeNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for Lifetime<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1238,12 +1520,20 @@ impl> LifetimeNode { impl<'a> Lifetime<'a> {} // LifetimeParam -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct LifetimeParamNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type LifetimeParam<'a> = LifetimeParamNode>; +impl, R2: TreeRoot> PartialEq> for LifetimeParamNode { + fn eq(&self, other: &LifetimeParamNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for LifetimeParamNode {} +impl> Hash for LifetimeParamNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for LifetimeParam<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1271,12 +1561,20 @@ impl<'a> LifetimeParam<'a> { } // Literal -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct LiteralNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type Literal<'a> = LiteralNode>; +impl, R2: TreeRoot> PartialEq> for LiteralNode { + fn eq(&self, other: &LiteralNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for LiteralNode {} +impl> Hash for LiteralNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for Literal<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1300,12 +1598,20 @@ impl> LiteralNode { impl<'a> Literal<'a> {} // LoopExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct LoopExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type LoopExpr<'a> = LoopExprNode>; +impl, R2: TreeRoot> PartialEq> for LoopExprNode { + fn eq(&self, other: &LoopExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for LoopExprNode {} +impl> Hash for LoopExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for LoopExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1330,12 +1636,20 @@ impl<'a> ast::LoopBodyOwner<'a> for LoopExpr<'a> {} impl<'a> LoopExpr<'a> {} // MatchArm -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct MatchArmNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type MatchArm<'a> = MatchArmNode>; +impl, R2: TreeRoot> PartialEq> for MatchArmNode { + fn eq(&self, other: &MatchArmNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for MatchArmNode {} +impl> Hash for MatchArmNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for MatchArm<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1371,12 +1685,20 @@ impl<'a> MatchArm<'a> { } // MatchArmList -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct MatchArmListNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type MatchArmList<'a> = MatchArmListNode>; +impl, R2: TreeRoot> PartialEq> for MatchArmListNode { + fn eq(&self, other: &MatchArmListNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for MatchArmListNode {} +impl> Hash for MatchArmListNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for MatchArmList<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1404,12 +1726,20 @@ impl<'a> MatchArmList<'a> { } // MatchExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct MatchExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type MatchExpr<'a> = MatchExprNode>; +impl, R2: TreeRoot> PartialEq> for MatchExprNode { + fn eq(&self, other: &MatchExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for MatchExprNode {} +impl> Hash for MatchExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for MatchExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1441,12 +1771,20 @@ impl<'a> MatchExpr<'a> { } // MatchGuard -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct MatchGuardNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type MatchGuard<'a> = MatchGuardNode>; +impl, R2: TreeRoot> PartialEq> for MatchGuardNode { + fn eq(&self, other: &MatchGuardNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for MatchGuardNode {} +impl> Hash for MatchGuardNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for MatchGuard<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1470,12 +1808,20 @@ impl> MatchGuardNode { impl<'a> MatchGuard<'a> {} // MethodCallExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct MethodCallExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type MethodCallExpr<'a> = MethodCallExprNode>; +impl, R2: TreeRoot> PartialEq> for MethodCallExprNode { + fn eq(&self, other: &MethodCallExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for MethodCallExprNode {} +impl> Hash for MethodCallExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for MethodCallExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1504,12 +1850,20 @@ impl<'a> MethodCallExpr<'a> { } // Module -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct ModuleNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type Module<'a> = ModuleNode>; +impl, R2: TreeRoot> PartialEq> for ModuleNode { + fn eq(&self, other: &ModuleNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for ModuleNode {} +impl> Hash for ModuleNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for Module<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1539,7 +1893,7 @@ impl<'a> Module<'a> { } // ModuleItem -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy, PartialEq, Eq)] pub enum ModuleItem<'a> { StructDef(StructDef<'a>), EnumDef(EnumDef<'a>), @@ -1591,12 +1945,20 @@ impl<'a> AstNode<'a> for ModuleItem<'a> { impl<'a> ModuleItem<'a> {} // Name -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct NameNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type Name<'a> = NameNode>; +impl, R2: TreeRoot> PartialEq> for NameNode { + fn eq(&self, other: &NameNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for NameNode {} +impl> Hash for NameNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for Name<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1620,12 +1982,20 @@ impl> NameNode { impl<'a> Name<'a> {} // NameRef -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct NameRefNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type NameRef<'a> = NameRefNode>; +impl, R2: TreeRoot> PartialEq> for NameRefNode { + fn eq(&self, other: &NameRefNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for NameRefNode {} +impl> Hash for NameRefNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for NameRef<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1649,12 +2019,20 @@ impl> NameRefNode { impl<'a> NameRef<'a> {} // NamedField -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct NamedFieldNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type NamedField<'a> = NamedFieldNode>; +impl, R2: TreeRoot> PartialEq> for NamedFieldNode { + fn eq(&self, other: &NamedFieldNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for NamedFieldNode {} +impl> Hash for NamedFieldNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for NamedField<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1678,12 +2056,20 @@ impl> NamedFieldNode { impl<'a> NamedField<'a> {} // NamedFieldDef -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct NamedFieldDefNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type NamedFieldDef<'a> = NamedFieldDefNode>; +impl, R2: TreeRoot> PartialEq> for NamedFieldDefNode { + fn eq(&self, other: &NamedFieldDefNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for NamedFieldDefNode {} +impl> Hash for NamedFieldDefNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for NamedFieldDef<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1709,12 +2095,20 @@ impl<'a> ast::AttrsOwner<'a> for NamedFieldDef<'a> {} impl<'a> NamedFieldDef<'a> {} // NamedFieldList -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct NamedFieldListNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type NamedFieldList<'a> = NamedFieldListNode>; +impl, R2: TreeRoot> PartialEq> for NamedFieldListNode { + fn eq(&self, other: &NamedFieldListNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for NamedFieldListNode {} +impl> Hash for NamedFieldListNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for NamedFieldList<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1738,12 +2132,20 @@ impl> NamedFieldListNode { impl<'a> NamedFieldList<'a> {} // NeverType -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct NeverTypeNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type NeverType<'a> = NeverTypeNode>; +impl, R2: TreeRoot> PartialEq> for NeverTypeNode { + fn eq(&self, other: &NeverTypeNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for NeverTypeNode {} +impl> Hash for NeverTypeNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for NeverType<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1767,7 +2169,7 @@ impl> NeverTypeNode { impl<'a> NeverType<'a> {} // NominalDef -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy, PartialEq, Eq)] pub enum NominalDef<'a> { StructDef(StructDef<'a>), EnumDef(EnumDef<'a>), @@ -1795,12 +2197,20 @@ impl<'a> ast::AttrsOwner<'a> for NominalDef<'a> {} impl<'a> NominalDef<'a> {} // Param -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct ParamNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type Param<'a> = ParamNode>; +impl, R2: TreeRoot> PartialEq> for ParamNode { + fn eq(&self, other: &ParamNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for ParamNode {} +impl> Hash for ParamNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for Param<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1828,12 +2238,20 @@ impl<'a> Param<'a> { } // ParamList -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct ParamListNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type ParamList<'a> = ParamListNode>; +impl, R2: TreeRoot> PartialEq> for ParamListNode { + fn eq(&self, other: &ParamListNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for ParamListNode {} +impl> Hash for ParamListNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for ParamList<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1865,12 +2283,20 @@ impl<'a> ParamList<'a> { } // ParenExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct ParenExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type ParenExpr<'a> = ParenExprNode>; +impl, R2: TreeRoot> PartialEq> for ParenExprNode { + fn eq(&self, other: &ParenExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for ParenExprNode {} +impl> Hash for ParenExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for ParenExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1894,12 +2320,20 @@ impl> ParenExprNode { impl<'a> ParenExpr<'a> {} // ParenType -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct ParenTypeNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type ParenType<'a> = ParenTypeNode>; +impl, R2: TreeRoot> PartialEq> for ParenTypeNode { + fn eq(&self, other: &ParenTypeNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for ParenTypeNode {} +impl> Hash for ParenTypeNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for ParenType<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -1923,7 +2357,7 @@ impl> ParenTypeNode { impl<'a> ParenType<'a> {} // Pat -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy, PartialEq, Eq)] pub enum Pat<'a> { RefPat(RefPat<'a>), BindPat(BindPat<'a>), @@ -1972,12 +2406,20 @@ impl<'a> AstNode<'a> for Pat<'a> { impl<'a> Pat<'a> {} // Path -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct PathNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type Path<'a> = PathNode>; +impl, R2: TreeRoot> PartialEq> for PathNode { + fn eq(&self, other: &PathNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for PathNode {} +impl> Hash for PathNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for Path<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2009,12 +2451,20 @@ impl<'a> Path<'a> { } // PathExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct PathExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type PathExpr<'a> = PathExprNode>; +impl, R2: TreeRoot> PartialEq> for PathExprNode { + fn eq(&self, other: &PathExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for PathExprNode {} +impl> Hash for PathExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for PathExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2042,12 +2492,20 @@ impl<'a> PathExpr<'a> { } // PathPat -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct PathPatNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type PathPat<'a> = PathPatNode>; +impl, R2: TreeRoot> PartialEq> for PathPatNode { + fn eq(&self, other: &PathPatNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for PathPatNode {} +impl> Hash for PathPatNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for PathPat<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2071,12 +2529,20 @@ impl> PathPatNode { impl<'a> PathPat<'a> {} // PathSegment -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct PathSegmentNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type PathSegment<'a> = PathSegmentNode>; +impl, R2: TreeRoot> PartialEq> for PathSegmentNode { + fn eq(&self, other: &PathSegmentNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for PathSegmentNode {} +impl> Hash for PathSegmentNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for PathSegment<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2104,12 +2570,20 @@ impl<'a> PathSegment<'a> { } // PathType -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct PathTypeNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type PathType<'a> = PathTypeNode>; +impl, R2: TreeRoot> PartialEq> for PathTypeNode { + fn eq(&self, other: &PathTypeNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for PathTypeNode {} +impl> Hash for PathTypeNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for PathType<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2133,12 +2607,20 @@ impl> PathTypeNode { impl<'a> PathType<'a> {} // PlaceholderPat -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct PlaceholderPatNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type PlaceholderPat<'a> = PlaceholderPatNode>; +impl, R2: TreeRoot> PartialEq> for PlaceholderPatNode { + fn eq(&self, other: &PlaceholderPatNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for PlaceholderPatNode {} +impl> Hash for PlaceholderPatNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for PlaceholderPat<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2162,12 +2644,20 @@ impl> PlaceholderPatNode { impl<'a> PlaceholderPat<'a> {} // PlaceholderType -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct PlaceholderTypeNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type PlaceholderType<'a> = PlaceholderTypeNode>; +impl, R2: TreeRoot> PartialEq> for PlaceholderTypeNode { + fn eq(&self, other: &PlaceholderTypeNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for PlaceholderTypeNode {} +impl> Hash for PlaceholderTypeNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for PlaceholderType<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2191,12 +2681,20 @@ impl> PlaceholderTypeNode { impl<'a> PlaceholderType<'a> {} // PointerType -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct PointerTypeNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type PointerType<'a> = PointerTypeNode>; +impl, R2: TreeRoot> PartialEq> for PointerTypeNode { + fn eq(&self, other: &PointerTypeNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for PointerTypeNode {} +impl> Hash for PointerTypeNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for PointerType<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2220,12 +2718,20 @@ impl> PointerTypeNode { impl<'a> PointerType<'a> {} // PrefixExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct PrefixExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type PrefixExpr<'a> = PrefixExprNode>; +impl, R2: TreeRoot> PartialEq> for PrefixExprNode { + fn eq(&self, other: &PrefixExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for PrefixExprNode {} +impl> Hash for PrefixExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for PrefixExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2249,12 +2755,20 @@ impl> PrefixExprNode { impl<'a> PrefixExpr<'a> {} // RangeExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct RangeExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type RangeExpr<'a> = RangeExprNode>; +impl, R2: TreeRoot> PartialEq> for RangeExprNode { + fn eq(&self, other: &RangeExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for RangeExprNode {} +impl> Hash for RangeExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for RangeExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2278,12 +2792,20 @@ impl> RangeExprNode { impl<'a> RangeExpr<'a> {} // RangePat -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct RangePatNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type RangePat<'a> = RangePatNode>; +impl, R2: TreeRoot> PartialEq> for RangePatNode { + fn eq(&self, other: &RangePatNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for RangePatNode {} +impl> Hash for RangePatNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for RangePat<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2307,12 +2829,20 @@ impl> RangePatNode { impl<'a> RangePat<'a> {} // RefExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct RefExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type RefExpr<'a> = RefExprNode>; +impl, R2: TreeRoot> PartialEq> for RefExprNode { + fn eq(&self, other: &RefExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for RefExprNode {} +impl> Hash for RefExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for RefExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2336,12 +2866,20 @@ impl> RefExprNode { impl<'a> RefExpr<'a> {} // RefPat -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct RefPatNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type RefPat<'a> = RefPatNode>; +impl, R2: TreeRoot> PartialEq> for RefPatNode { + fn eq(&self, other: &RefPatNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for RefPatNode {} +impl> Hash for RefPatNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for RefPat<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2365,12 +2903,20 @@ impl> RefPatNode { impl<'a> RefPat<'a> {} // ReferenceType -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct ReferenceTypeNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type ReferenceType<'a> = ReferenceTypeNode>; +impl, R2: TreeRoot> PartialEq> for ReferenceTypeNode { + fn eq(&self, other: &ReferenceTypeNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for ReferenceTypeNode {} +impl> Hash for ReferenceTypeNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for ReferenceType<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2394,12 +2940,20 @@ impl> ReferenceTypeNode { impl<'a> ReferenceType<'a> {} // RetType -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct RetTypeNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type RetType<'a> = RetTypeNode>; +impl, R2: TreeRoot> PartialEq> for RetTypeNode { + fn eq(&self, other: &RetTypeNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for RetTypeNode {} +impl> Hash for RetTypeNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for RetType<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2423,12 +2977,20 @@ impl> RetTypeNode { impl<'a> RetType<'a> {} // ReturnExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct ReturnExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type ReturnExpr<'a> = ReturnExprNode>; +impl, R2: TreeRoot> PartialEq> for ReturnExprNode { + fn eq(&self, other: &ReturnExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for ReturnExprNode {} +impl> Hash for ReturnExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for ReturnExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2452,12 +3014,20 @@ impl> ReturnExprNode { impl<'a> ReturnExpr<'a> {} // Root -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct RootNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type Root<'a> = RootNode>; +impl, R2: TreeRoot> PartialEq> for RootNode { + fn eq(&self, other: &RootNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for RootNode {} +impl> Hash for RootNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for Root<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2487,12 +3057,20 @@ impl<'a> Root<'a> { } // SelfParam -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct SelfParamNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type SelfParam<'a> = SelfParamNode>; +impl, R2: TreeRoot> PartialEq> for SelfParamNode { + fn eq(&self, other: &SelfParamNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for SelfParamNode {} +impl> Hash for SelfParamNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for SelfParam<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2516,12 +3094,20 @@ impl> SelfParamNode { impl<'a> SelfParam<'a> {} // SlicePat -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct SlicePatNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type SlicePat<'a> = SlicePatNode>; +impl, R2: TreeRoot> PartialEq> for SlicePatNode { + fn eq(&self, other: &SlicePatNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for SlicePatNode {} +impl> Hash for SlicePatNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for SlicePat<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2545,12 +3131,20 @@ impl> SlicePatNode { impl<'a> SlicePat<'a> {} // SliceType -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct SliceTypeNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type SliceType<'a> = SliceTypeNode>; +impl, R2: TreeRoot> PartialEq> for SliceTypeNode { + fn eq(&self, other: &SliceTypeNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for SliceTypeNode {} +impl> Hash for SliceTypeNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for SliceType<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2574,12 +3168,20 @@ impl> SliceTypeNode { impl<'a> SliceType<'a> {} // StaticDef -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct StaticDefNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type StaticDef<'a> = StaticDefNode>; +impl, R2: TreeRoot> PartialEq> for StaticDefNode { + fn eq(&self, other: &StaticDefNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for StaticDefNode {} +impl> Hash for StaticDefNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for StaticDef<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2606,7 +3208,7 @@ impl<'a> ast::AttrsOwner<'a> for StaticDef<'a> {} impl<'a> StaticDef<'a> {} // Stmt -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy, PartialEq, Eq)] pub enum Stmt<'a> { ExprStmt(ExprStmt<'a>), LetStmt(LetStmt<'a>), @@ -2631,12 +3233,20 @@ impl<'a> AstNode<'a> for Stmt<'a> { impl<'a> Stmt<'a> {} // StructDef -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct StructDefNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type StructDef<'a> = StructDefNode>; +impl, R2: TreeRoot> PartialEq> for StructDefNode { + fn eq(&self, other: &StructDefNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for StructDefNode {} +impl> Hash for StructDefNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for StructDef<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2667,12 +3277,20 @@ impl<'a> StructDef<'a> { } // StructLit -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct StructLitNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type StructLit<'a> = StructLitNode>; +impl, R2: TreeRoot> PartialEq> for StructLitNode { + fn eq(&self, other: &StructLitNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for StructLitNode {} +impl> Hash for StructLitNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for StructLit<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2696,12 +3314,20 @@ impl> StructLitNode { impl<'a> StructLit<'a> {} // StructPat -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct StructPatNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type StructPat<'a> = StructPatNode>; +impl, R2: TreeRoot> PartialEq> for StructPatNode { + fn eq(&self, other: &StructPatNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for StructPatNode {} +impl> Hash for StructPatNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for StructPat<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2725,12 +3351,20 @@ impl> StructPatNode { impl<'a> StructPat<'a> {} // TokenTree -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct TokenTreeNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type TokenTree<'a> = TokenTreeNode>; +impl, R2: TreeRoot> PartialEq> for TokenTreeNode { + fn eq(&self, other: &TokenTreeNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for TokenTreeNode {} +impl> Hash for TokenTreeNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for TokenTree<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2754,12 +3388,20 @@ impl> TokenTreeNode { impl<'a> TokenTree<'a> {} // TraitDef -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct TraitDefNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type TraitDef<'a> = TraitDefNode>; +impl, R2: TreeRoot> PartialEq> for TraitDefNode { + fn eq(&self, other: &TraitDefNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for TraitDefNode {} +impl> Hash for TraitDefNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for TraitDef<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2785,12 +3427,20 @@ impl<'a> ast::AttrsOwner<'a> for TraitDef<'a> {} impl<'a> TraitDef<'a> {} // TryExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct TryExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type TryExpr<'a> = TryExprNode>; +impl, R2: TreeRoot> PartialEq> for TryExprNode { + fn eq(&self, other: &TryExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for TryExprNode {} +impl> Hash for TryExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for TryExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2814,12 +3464,20 @@ impl> TryExprNode { impl<'a> TryExpr<'a> {} // TupleExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct TupleExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type TupleExpr<'a> = TupleExprNode>; +impl, R2: TreeRoot> PartialEq> for TupleExprNode { + fn eq(&self, other: &TupleExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for TupleExprNode {} +impl> Hash for TupleExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for TupleExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2843,12 +3501,20 @@ impl> TupleExprNode { impl<'a> TupleExpr<'a> {} // TuplePat -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct TuplePatNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type TuplePat<'a> = TuplePatNode>; +impl, R2: TreeRoot> PartialEq> for TuplePatNode { + fn eq(&self, other: &TuplePatNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for TuplePatNode {} +impl> Hash for TuplePatNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for TuplePat<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2872,12 +3538,20 @@ impl> TuplePatNode { impl<'a> TuplePat<'a> {} // TupleStructPat -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct TupleStructPatNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type TupleStructPat<'a> = TupleStructPatNode>; +impl, R2: TreeRoot> PartialEq> for TupleStructPatNode { + fn eq(&self, other: &TupleStructPatNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for TupleStructPatNode {} +impl> Hash for TupleStructPatNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for TupleStructPat<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2901,12 +3575,20 @@ impl> TupleStructPatNode { impl<'a> TupleStructPat<'a> {} // TupleType -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct TupleTypeNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type TupleType<'a> = TupleTypeNode>; +impl, R2: TreeRoot> PartialEq> for TupleTypeNode { + fn eq(&self, other: &TupleTypeNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for TupleTypeNode {} +impl> Hash for TupleTypeNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for TupleType<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2930,12 +3612,20 @@ impl> TupleTypeNode { impl<'a> TupleType<'a> {} // TypeDef -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct TypeDefNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type TypeDef<'a> = TypeDefNode>; +impl, R2: TreeRoot> PartialEq> for TypeDefNode { + fn eq(&self, other: &TypeDefNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for TypeDefNode {} +impl> Hash for TypeDefNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for TypeDef<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2962,12 +3652,20 @@ impl<'a> ast::AttrsOwner<'a> for TypeDef<'a> {} impl<'a> TypeDef<'a> {} // TypeParam -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct TypeParamNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type TypeParam<'a> = TypeParamNode>; +impl, R2: TreeRoot> PartialEq> for TypeParamNode { + fn eq(&self, other: &TypeParamNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for TypeParamNode {} +impl> Hash for TypeParamNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for TypeParam<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -2992,12 +3690,20 @@ impl<'a> ast::NameOwner<'a> for TypeParam<'a> {} impl<'a> TypeParam<'a> {} // TypeParamList -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct TypeParamListNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type TypeParamList<'a> = TypeParamListNode>; +impl, R2: TreeRoot> PartialEq> for TypeParamListNode { + fn eq(&self, other: &TypeParamListNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for TypeParamListNode {} +impl> Hash for TypeParamListNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for TypeParamList<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -3029,7 +3735,7 @@ impl<'a> TypeParamList<'a> { } // TypeRef -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy, PartialEq, Eq)] pub enum TypeRef<'a> { ParenType(ParenType<'a>), TupleType(TupleType<'a>), @@ -3087,12 +3793,20 @@ impl<'a> AstNode<'a> for TypeRef<'a> { impl<'a> TypeRef<'a> {} // UseItem -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct UseItemNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type UseItem<'a> = UseItemNode>; +impl, R2: TreeRoot> PartialEq> for UseItemNode { + fn eq(&self, other: &UseItemNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for UseItemNode {} +impl> Hash for UseItemNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for UseItem<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -3120,12 +3834,20 @@ impl<'a> UseItem<'a> { } // UseTree -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct UseTreeNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type UseTree<'a> = UseTreeNode>; +impl, R2: TreeRoot> PartialEq> for UseTreeNode { + fn eq(&self, other: &UseTreeNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for UseTreeNode {} +impl> Hash for UseTreeNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for UseTree<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -3157,12 +3879,20 @@ impl<'a> UseTree<'a> { } // UseTreeList -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct UseTreeListNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type UseTreeList<'a> = UseTreeListNode>; +impl, R2: TreeRoot> PartialEq> for UseTreeListNode { + fn eq(&self, other: &UseTreeListNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for UseTreeListNode {} +impl> Hash for UseTreeListNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for UseTreeList<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -3190,12 +3920,20 @@ impl<'a> UseTreeList<'a> { } // WhereClause -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct WhereClauseNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type WhereClause<'a> = WhereClauseNode>; +impl, R2: TreeRoot> PartialEq> for WhereClauseNode { + fn eq(&self, other: &WhereClauseNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for WhereClauseNode {} +impl> Hash for WhereClauseNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for WhereClause<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -3219,12 +3957,20 @@ impl> WhereClauseNode { impl<'a> WhereClause<'a> {} // WhileExpr -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct WhileExprNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type WhileExpr<'a> = WhileExprNode>; +impl, R2: TreeRoot> PartialEq> for WhileExprNode { + fn eq(&self, other: &WhileExprNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for WhileExprNode {} +impl> Hash for WhileExprNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for WhileExpr<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { @@ -3253,12 +3999,20 @@ impl<'a> WhileExpr<'a> { } // Whitespace -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct WhitespaceNode = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type Whitespace<'a> = WhitespaceNode>; +impl, R2: TreeRoot> PartialEq> for WhitespaceNode { + fn eq(&self, other: &WhitespaceNode) -> bool { self.syntax == other.syntax } +} +impl> Eq for WhitespaceNode {} +impl> Hash for WhitespaceNode { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for Whitespace<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { diff --git a/crates/ra_syntax/src/ast/generated.rs.tera b/crates/ra_syntax/src/ast/generated.rs.tera index d4fc6b5bd..131ee09ec 100644 --- a/crates/ra_syntax/src/ast/generated.rs.tera +++ b/crates/ra_syntax/src/ast/generated.rs.tera @@ -11,6 +11,8 @@ the below applies to the result of this template #![cfg_attr(rustfmt, rustfmt_skip)] +use std::hash::{Hash, Hasher}; + use crate::{ ast, SyntaxNode, SyntaxNodeRef, AstNode, @@ -21,7 +23,7 @@ use crate::{ // {{ node }} {%- if methods.enum %} -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy, PartialEq, Eq)] pub enum {{ node }}<'a> { {%- for kind in methods.enum %} {{ kind }}({{ kind }}<'a>), @@ -46,12 +48,20 @@ impl<'a> AstNode<'a> for {{ node }}<'a> { } } {% else %} -#[derive(Debug, Clone, Copy)] +#[derive(Debug, Clone, Copy,)] pub struct {{ node }}Node = OwnedRoot> { - syntax: SyntaxNode, + pub(crate) syntax: SyntaxNode, } pub type {{ node }}<'a> = {{ node }}Node>; +impl, R2: TreeRoot> PartialEq<{{node}}Node> for {{node}}Node { + fn eq(&self, other: &{{node}}Node) -> bool { self.syntax == other.syntax } +} +impl> Eq for {{node}}Node {} +impl> Hash for {{node}}Node { + fn hash(&self, state: &mut H) { self.syntax.hash(state) } +} + impl<'a> AstNode<'a> for {{ node }}<'a> { fn cast(syntax: SyntaxNodeRef<'a>) -> Option { match syntax.kind() { -- cgit v1.2.3