aboutsummaryrefslogtreecommitdiff
path: root/crates/ra_ide_api/src/goto_definition.rs
diff options
context:
space:
mode:
authorJeremy Kolb <[email protected]>2019-03-02 19:05:37 +0000
committerJeremy Kolb <[email protected]>2019-03-04 13:27:08 +0000
commit3d8d880c59bee2f6aa21800b8b147aff47d6b0b8 (patch)
tree2508f84434ff6ccdc6a0bc0bdce6c5cc5e9f0bb1 /crates/ra_ide_api/src/goto_definition.rs
parent49da9a3e814a42a2f4dea0cd79dbdae86bea5ce4 (diff)
Use ImplItems instead of just Function
Diffstat (limited to 'crates/ra_ide_api/src/goto_definition.rs')
-rw-r--r--crates/ra_ide_api/src/goto_definition.rs21
1 files changed, 16 insertions, 5 deletions
diff --git a/crates/ra_ide_api/src/goto_definition.rs b/crates/ra_ide_api/src/goto_definition.rs
index e4febe8cc..3b66483cb 100644
--- a/crates/ra_ide_api/src/goto_definition.rs
+++ b/crates/ra_ide_api/src/goto_definition.rs
@@ -5,7 +5,7 @@ use ra_syntax::{
5 SyntaxNode, 5 SyntaxNode,
6}; 6};
7use test_utils::tested_by; 7use test_utils::tested_by;
8use hir::Resolution; 8use hir::{ImplItem, Resolution};
9 9
10use crate::{FilePosition, NavigationTarget, db::RootDatabase, RangeInfo}; 10use crate::{FilePosition, NavigationTarget, db::RootDatabase, RangeInfo};
11 11
@@ -131,14 +131,25 @@ pub(crate) fn reference_definition(
131 name_ref.syntax().ancestors().find_map(ast::PathExpr::cast) 131 name_ref.syntax().ancestors().find_map(ast::PathExpr::cast)
132 { 132 {
133 let infer_result = function.infer(db); 133 let infer_result = function.infer(db);
134 let syntax_mapping = function.body_syntax_mapping(db); 134 let source_map = function.body_source_map(db);
135 let expr = ast::Expr::cast(path_expr.syntax()).unwrap(); 135 let expr = ast::Expr::cast(path_expr.syntax()).unwrap();
136 136
137 if let Some(func) = syntax_mapping 137 if let Some(res) = source_map
138 .node_expr(expr) 138 .node_expr(expr)
139 .and_then(|it| infer_result.assoc_fn_resolutions(it)) 139 .and_then(|it| infer_result.assoc_resolutions(it.into()))
140 { 140 {
141 return Exact(NavigationTarget::from_function(db, func)); 141 match res {
142 ImplItem::Method(f) => {
143 return Exact(NavigationTarget::from_function(db, f));
144 }
145 ImplItem::Const(c) => {
146 let (file, node) = c.source(db);
147 let file = file.original_file(db);
148 let node = &*node;
149 return Exact(NavigationTarget::from_named(file, node));
150 }
151 _ => {}
152 }
142 } 153 }
143 } 154 }
144 } 155 }