mirror of
https://github.com/rust-lang/rust-analyzer.git
synced 2025-09-28 04:44:57 +00:00
more renames
This commit is contained in:
parent
2e971cdcbb
commit
78f41ea707
11 changed files with 79 additions and 21 deletions
|
@ -4,6 +4,30 @@ use {
|
|||
SyntaxKind::*,
|
||||
};
|
||||
|
||||
#[derive(Debug, Clone, Copy)]
|
||||
pub struct Enum<R: TreeRoot = Arc<SyntaxRoot>> {
|
||||
syntax: SyntaxNode<R>,
|
||||
}
|
||||
|
||||
impl<R: TreeRoot> AstNode<R> for Enum<R> {
|
||||
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
|
||||
match syntax.kind() {
|
||||
ENUM => Some(Enum { syntax }),
|
||||
_ => None,
|
||||
}
|
||||
}
|
||||
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
|
||||
}
|
||||
|
||||
impl<R: TreeRoot> Enum<R> {
|
||||
pub fn name(&self) -> Option<Name<R>> {
|
||||
self.syntax()
|
||||
.children()
|
||||
.filter_map(Name::cast)
|
||||
.next()
|
||||
}
|
||||
}
|
||||
|
||||
#[derive(Debug, Clone, Copy)]
|
||||
pub struct File<R: TreeRoot = Arc<SyntaxRoot>> {
|
||||
syntax: SyntaxNode<R>,
|
||||
|
@ -68,3 +92,27 @@ impl<R: TreeRoot> AstNode<R> for Name<R> {
|
|||
|
||||
impl<R: TreeRoot> Name<R> {}
|
||||
|
||||
#[derive(Debug, Clone, Copy)]
|
||||
pub struct Struct<R: TreeRoot = Arc<SyntaxRoot>> {
|
||||
syntax: SyntaxNode<R>,
|
||||
}
|
||||
|
||||
impl<R: TreeRoot> AstNode<R> for Struct<R> {
|
||||
fn cast(syntax: SyntaxNode<R>) -> Option<Self> {
|
||||
match syntax.kind() {
|
||||
STRUCT => Some(Struct { syntax }),
|
||||
_ => None,
|
||||
}
|
||||
}
|
||||
fn syntax(&self) -> &SyntaxNode<R> { &self.syntax }
|
||||
}
|
||||
|
||||
impl<R: TreeRoot> Struct<R> {
|
||||
pub fn name(&self) -> Option<Name<R>> {
|
||||
self.syntax()
|
||||
.children()
|
||||
.filter_map(Name::cast)
|
||||
.next()
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -112,11 +112,11 @@ Grammar(
|
|||
"ENUM",
|
||||
"FUNCTION",
|
||||
"EXTERN_CRATE_ITEM",
|
||||
"MOD_ITEM",
|
||||
"MODULE",
|
||||
"USE_ITEM",
|
||||
"STATIC_ITEM",
|
||||
"CONST_ITEM",
|
||||
"TRAIT_ITEM",
|
||||
"TRAIT",
|
||||
"IMPL_ITEM",
|
||||
"TYPE_ITEM",
|
||||
"MACRO_CALL",
|
||||
|
@ -224,6 +224,16 @@ Grammar(
|
|||
["name", "Name"]
|
||||
]
|
||||
),
|
||||
"Struct": (
|
||||
options: [
|
||||
["name", "Name"]
|
||||
]
|
||||
),
|
||||
"Enum": (
|
||||
options: [
|
||||
["name", "Name"]
|
||||
]
|
||||
),
|
||||
"Name": (),
|
||||
},
|
||||
)
|
||||
|
|
|
@ -121,7 +121,7 @@ pub(super) fn maybe_item(p: &mut Parser) -> MaybeItem {
|
|||
// unsafe auto trait T {}
|
||||
TRAIT_KW => {
|
||||
traits::trait_item(p);
|
||||
TRAIT_ITEM
|
||||
TRAIT
|
||||
}
|
||||
|
||||
// test unsafe_impl
|
||||
|
@ -161,7 +161,7 @@ fn items_without_modifiers(p: &mut Parser) -> Option<SyntaxKind> {
|
|||
}
|
||||
MOD_KW => {
|
||||
mod_item(p);
|
||||
MOD_ITEM
|
||||
MODULE
|
||||
}
|
||||
STRUCT_KW => {
|
||||
structs::struct_item(p);
|
||||
|
|
|
@ -112,11 +112,11 @@ pub enum SyntaxKind {
|
|||
ENUM,
|
||||
FUNCTION,
|
||||
EXTERN_CRATE_ITEM,
|
||||
MOD_ITEM,
|
||||
MODULE,
|
||||
USE_ITEM,
|
||||
STATIC_ITEM,
|
||||
CONST_ITEM,
|
||||
TRAIT_ITEM,
|
||||
TRAIT,
|
||||
IMPL_ITEM,
|
||||
TYPE_ITEM,
|
||||
MACRO_CALL,
|
||||
|
@ -347,11 +347,11 @@ impl SyntaxKind {
|
|||
ENUM => &SyntaxInfo { name: "ENUM" },
|
||||
FUNCTION => &SyntaxInfo { name: "FUNCTION" },
|
||||
EXTERN_CRATE_ITEM => &SyntaxInfo { name: "EXTERN_CRATE_ITEM" },
|
||||
MOD_ITEM => &SyntaxInfo { name: "MOD_ITEM" },
|
||||
MODULE => &SyntaxInfo { name: "MODULE" },
|
||||
USE_ITEM => &SyntaxInfo { name: "USE_ITEM" },
|
||||
STATIC_ITEM => &SyntaxInfo { name: "STATIC_ITEM" },
|
||||
CONST_ITEM => &SyntaxInfo { name: "CONST_ITEM" },
|
||||
TRAIT_ITEM => &SyntaxInfo { name: "TRAIT_ITEM" },
|
||||
TRAIT => &SyntaxInfo { name: "TRAIT" },
|
||||
IMPL_ITEM => &SyntaxInfo { name: "IMPL_ITEM" },
|
||||
TYPE_ITEM => &SyntaxInfo { name: "TYPE_ITEM" },
|
||||
MACRO_CALL => &SyntaxInfo { name: "MACRO_CALL" },
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue