mirror of
https://github.com/rust-lang/rust-analyzer.git
synced 2025-09-27 12:29:21 +00:00
move nav to a separate file
This commit is contained in:
parent
f848aa97ab
commit
2aa125251e
2 changed files with 88 additions and 73 deletions
|
@ -22,6 +22,7 @@ mod db;
|
||||||
mod imp;
|
mod imp;
|
||||||
pub mod mock_analysis;
|
pub mod mock_analysis;
|
||||||
mod symbol_index;
|
mod symbol_index;
|
||||||
|
mod navigation_target;
|
||||||
|
|
||||||
mod completion;
|
mod completion;
|
||||||
mod runnables;
|
mod runnables;
|
||||||
|
@ -33,8 +34,7 @@ mod syntax_highlighting;
|
||||||
|
|
||||||
use std::{fmt, sync::Arc};
|
use std::{fmt, sync::Arc};
|
||||||
|
|
||||||
use hir::{Def, ModuleSource, Name};
|
use ra_syntax::{SmolStr, SourceFile, TreePtr, SyntaxKind, TextRange, TextUnit};
|
||||||
use ra_syntax::{SmolStr, SourceFile, TreePtr, SyntaxKind, SyntaxNode, TextRange, TextUnit, AstNode};
|
|
||||||
use ra_text_edit::TextEdit;
|
use ra_text_edit::TextEdit;
|
||||||
use ra_db::{SyntaxDatabase, FilesDatabase, LocalSyntaxPtr, BaseDatabase};
|
use ra_db::{SyntaxDatabase, FilesDatabase, LocalSyntaxPtr, BaseDatabase};
|
||||||
use rayon::prelude::*;
|
use rayon::prelude::*;
|
||||||
|
@ -259,77 +259,6 @@ pub struct NavigationTarget {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl NavigationTarget {
|
impl NavigationTarget {
|
||||||
fn from_symbol(symbol: FileSymbol) -> NavigationTarget {
|
|
||||||
NavigationTarget {
|
|
||||||
file_id: symbol.file_id,
|
|
||||||
name: symbol.name.clone(),
|
|
||||||
kind: symbol.ptr.kind(),
|
|
||||||
range: symbol.ptr.range(),
|
|
||||||
ptr: Some(symbol.ptr.clone()),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
fn from_syntax(name: Option<Name>, file_id: FileId, node: &SyntaxNode) -> NavigationTarget {
|
|
||||||
NavigationTarget {
|
|
||||||
file_id,
|
|
||||||
name: name.map(|n| n.to_string().into()).unwrap_or("".into()),
|
|
||||||
kind: node.kind(),
|
|
||||||
range: node.range(),
|
|
||||||
ptr: Some(LocalSyntaxPtr::new(node)),
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// TODO once Def::Item is gone, this should be able to always return a NavigationTarget
|
|
||||||
fn from_def(db: &db::RootDatabase, def: Def) -> Cancelable<Option<NavigationTarget>> {
|
|
||||||
Ok(match def {
|
|
||||||
Def::Struct(s) => {
|
|
||||||
let (file_id, node) = s.source(db)?;
|
|
||||||
Some(NavigationTarget::from_syntax(
|
|
||||||
s.name(db)?,
|
|
||||||
file_id.original_file(db),
|
|
||||||
node.syntax(),
|
|
||||||
))
|
|
||||||
}
|
|
||||||
Def::Enum(e) => {
|
|
||||||
let (file_id, node) = e.source(db)?;
|
|
||||||
Some(NavigationTarget::from_syntax(
|
|
||||||
e.name(db)?,
|
|
||||||
file_id.original_file(db),
|
|
||||||
node.syntax(),
|
|
||||||
))
|
|
||||||
}
|
|
||||||
Def::EnumVariant(ev) => {
|
|
||||||
let (file_id, node) = ev.source(db)?;
|
|
||||||
Some(NavigationTarget::from_syntax(
|
|
||||||
ev.name(db)?,
|
|
||||||
file_id.original_file(db),
|
|
||||||
node.syntax(),
|
|
||||||
))
|
|
||||||
}
|
|
||||||
Def::Function(f) => {
|
|
||||||
let (file_id, node) = f.source(db)?;
|
|
||||||
let name = f.signature(db).name().clone();
|
|
||||||
Some(NavigationTarget::from_syntax(
|
|
||||||
Some(name),
|
|
||||||
file_id.original_file(db),
|
|
||||||
node.syntax(),
|
|
||||||
))
|
|
||||||
}
|
|
||||||
Def::Module(m) => {
|
|
||||||
let (file_id, source) = m.definition_source(db)?;
|
|
||||||
let name = m.name(db)?;
|
|
||||||
match source {
|
|
||||||
ModuleSource::SourceFile(node) => {
|
|
||||||
Some(NavigationTarget::from_syntax(name, file_id, node.syntax()))
|
|
||||||
}
|
|
||||||
ModuleSource::Module(node) => {
|
|
||||||
Some(NavigationTarget::from_syntax(name, file_id, node.syntax()))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Def::Item => None,
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn name(&self) -> &SmolStr {
|
pub fn name(&self) -> &SmolStr {
|
||||||
&self.name
|
&self.name
|
||||||
}
|
}
|
||||||
|
|
86
crates/ra_ide_api/src/navigation_target.rs
Normal file
86
crates/ra_ide_api/src/navigation_target.rs
Normal file
|
@ -0,0 +1,86 @@
|
||||||
|
use ra_db::{FileId, LocalSyntaxPtr, Cancelable};
|
||||||
|
use ra_syntax::{SyntaxNode, AstNode};
|
||||||
|
use hir::{Name, Def, ModuleSource};
|
||||||
|
|
||||||
|
use crate::{
|
||||||
|
NavigationTarget,
|
||||||
|
FileSymbol,
|
||||||
|
db::RootDatabase,
|
||||||
|
};
|
||||||
|
|
||||||
|
impl NavigationTarget {
|
||||||
|
pub(crate) fn from_symbol(symbol: FileSymbol) -> NavigationTarget {
|
||||||
|
NavigationTarget {
|
||||||
|
file_id: symbol.file_id,
|
||||||
|
name: symbol.name.clone(),
|
||||||
|
kind: symbol.ptr.kind(),
|
||||||
|
range: symbol.ptr.range(),
|
||||||
|
ptr: Some(symbol.ptr.clone()),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub(crate) fn from_syntax(
|
||||||
|
name: Option<Name>,
|
||||||
|
file_id: FileId,
|
||||||
|
node: &SyntaxNode,
|
||||||
|
) -> NavigationTarget {
|
||||||
|
NavigationTarget {
|
||||||
|
file_id,
|
||||||
|
name: name.map(|n| n.to_string().into()).unwrap_or("".into()),
|
||||||
|
kind: node.kind(),
|
||||||
|
range: node.range(),
|
||||||
|
ptr: Some(LocalSyntaxPtr::new(node)),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// TODO once Def::Item is gone, this should be able to always return a NavigationTarget
|
||||||
|
pub(crate) fn from_def(db: &RootDatabase, def: Def) -> Cancelable<Option<NavigationTarget>> {
|
||||||
|
Ok(match def {
|
||||||
|
Def::Struct(s) => {
|
||||||
|
let (file_id, node) = s.source(db)?;
|
||||||
|
Some(NavigationTarget::from_syntax(
|
||||||
|
s.name(db)?,
|
||||||
|
file_id.original_file(db),
|
||||||
|
node.syntax(),
|
||||||
|
))
|
||||||
|
}
|
||||||
|
Def::Enum(e) => {
|
||||||
|
let (file_id, node) = e.source(db)?;
|
||||||
|
Some(NavigationTarget::from_syntax(
|
||||||
|
e.name(db)?,
|
||||||
|
file_id.original_file(db),
|
||||||
|
node.syntax(),
|
||||||
|
))
|
||||||
|
}
|
||||||
|
Def::EnumVariant(ev) => {
|
||||||
|
let (file_id, node) = ev.source(db)?;
|
||||||
|
Some(NavigationTarget::from_syntax(
|
||||||
|
ev.name(db)?,
|
||||||
|
file_id.original_file(db),
|
||||||
|
node.syntax(),
|
||||||
|
))
|
||||||
|
}
|
||||||
|
Def::Function(f) => {
|
||||||
|
let (file_id, node) = f.source(db)?;
|
||||||
|
let name = f.signature(db).name().clone();
|
||||||
|
Some(NavigationTarget::from_syntax(
|
||||||
|
Some(name),
|
||||||
|
file_id.original_file(db),
|
||||||
|
node.syntax(),
|
||||||
|
))
|
||||||
|
}
|
||||||
|
Def::Module(m) => {
|
||||||
|
let (file_id, source) = m.definition_source(db)?;
|
||||||
|
let name = m.name(db)?;
|
||||||
|
match source {
|
||||||
|
ModuleSource::SourceFile(node) => {
|
||||||
|
Some(NavigationTarget::from_syntax(name, file_id, node.syntax()))
|
||||||
|
}
|
||||||
|
ModuleSource::Module(node) => {
|
||||||
|
Some(NavigationTarget::from_syntax(name, file_id, node.syntax()))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Def::Item => None,
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue