mirror of
https://github.com/rust-lang/rust-analyzer.git
synced 2025-10-01 06:11:35 +00:00
remove Canceled from API impl
This commit is contained in:
parent
02c3d2f78e
commit
05ba45c667
8 changed files with 61 additions and 76 deletions
|
@ -1,4 +1,4 @@
|
|||
use ra_db::{FileId, Cancelable, SyntaxDatabase};
|
||||
use ra_db::{FileId, SyntaxDatabase};
|
||||
use ra_syntax::{
|
||||
AstNode, ast,
|
||||
algo::find_node_at_offset,
|
||||
|
@ -9,21 +9,18 @@ use crate::{FilePosition, NavigationTarget, db::RootDatabase, RangeInfo};
|
|||
pub(crate) fn goto_definition(
|
||||
db: &RootDatabase,
|
||||
position: FilePosition,
|
||||
) -> Cancelable<Option<RangeInfo<Vec<NavigationTarget>>>> {
|
||||
) -> Option<RangeInfo<Vec<NavigationTarget>>> {
|
||||
let file = db.source_file(position.file_id);
|
||||
let syntax = file.syntax();
|
||||
if let Some(name_ref) = find_node_at_offset::<ast::NameRef>(syntax, position.offset) {
|
||||
let navs = reference_definition(db, position.file_id, name_ref)?.to_vec();
|
||||
return Ok(Some(RangeInfo::new(
|
||||
name_ref.syntax().range(),
|
||||
navs.to_vec(),
|
||||
)));
|
||||
let navs = reference_definition(db, position.file_id, name_ref).to_vec();
|
||||
return Some(RangeInfo::new(name_ref.syntax().range(), navs.to_vec()));
|
||||
}
|
||||
if let Some(name) = find_node_at_offset::<ast::Name>(syntax, position.offset) {
|
||||
let navs = ctry!(name_definition(db, position.file_id, name)?);
|
||||
return Ok(Some(RangeInfo::new(name.syntax().range(), navs)));
|
||||
let navs = name_definition(db, position.file_id, name)?;
|
||||
return Some(RangeInfo::new(name.syntax().range(), navs));
|
||||
}
|
||||
Ok(None)
|
||||
None
|
||||
}
|
||||
|
||||
pub(crate) enum ReferenceResult {
|
||||
|
@ -45,7 +42,7 @@ pub(crate) fn reference_definition(
|
|||
db: &RootDatabase,
|
||||
file_id: FileId,
|
||||
name_ref: &ast::NameRef,
|
||||
) -> Cancelable<ReferenceResult> {
|
||||
) -> ReferenceResult {
|
||||
use self::ReferenceResult::*;
|
||||
if let Some(function) =
|
||||
hir::source_binder::function_from_child_node(db, file_id, name_ref.syntax())
|
||||
|
@ -54,7 +51,7 @@ pub(crate) fn reference_definition(
|
|||
// First try to resolve the symbol locally
|
||||
if let Some(entry) = scope.resolve_local_name(name_ref) {
|
||||
let nav = NavigationTarget::from_scope_entry(file_id, &entry);
|
||||
return Ok(Exact(nav));
|
||||
return Exact(nav);
|
||||
};
|
||||
|
||||
// Next check if it is a method
|
||||
|
@ -71,7 +68,7 @@ pub(crate) fn reference_definition(
|
|||
.and_then(|it| infer_result.method_resolution(it))
|
||||
{
|
||||
if let Some(target) = NavigationTarget::from_def(db, def_id.resolve(db)) {
|
||||
return Ok(Exact(target));
|
||||
return Exact(target);
|
||||
}
|
||||
};
|
||||
}
|
||||
|
@ -88,7 +85,7 @@ pub(crate) fn reference_definition(
|
|||
let resolved = module.resolve_path(db, &path);
|
||||
if let Some(def_id) = resolved.take_types().or(resolved.take_values()) {
|
||||
if let Some(target) = NavigationTarget::from_def(db, def_id.resolve(db)) {
|
||||
return Ok(Exact(target));
|
||||
return Exact(target);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -99,25 +96,25 @@ pub(crate) fn reference_definition(
|
|||
.into_iter()
|
||||
.map(NavigationTarget::from_symbol)
|
||||
.collect();
|
||||
Ok(Approximate(navs))
|
||||
Approximate(navs)
|
||||
}
|
||||
|
||||
fn name_definition(
|
||||
db: &RootDatabase,
|
||||
file_id: FileId,
|
||||
name: &ast::Name,
|
||||
) -> Cancelable<Option<Vec<NavigationTarget>>> {
|
||||
) -> Option<Vec<NavigationTarget>> {
|
||||
if let Some(module) = name.syntax().parent().and_then(ast::Module::cast) {
|
||||
if module.has_semi() {
|
||||
if let Some(child_module) =
|
||||
hir::source_binder::module_from_declaration(db, file_id, module)
|
||||
{
|
||||
let nav = NavigationTarget::from_module(db, child_module);
|
||||
return Ok(Some(vec![nav]));
|
||||
return Some(vec![nav]);
|
||||
}
|
||||
}
|
||||
}
|
||||
Ok(None)
|
||||
None
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue