aboutsummaryrefslogtreecommitdiff
path: root/crates/ra_analysis/src/hir
diff options
context:
space:
mode:
Diffstat (limited to 'crates/ra_analysis/src/hir')
-rw-r--r--crates/ra_analysis/src/hir/function/mod.rs17
-rw-r--r--crates/ra_analysis/src/hir/mod.rs3
2 files changed, 12 insertions, 8 deletions
diff --git a/crates/ra_analysis/src/hir/function/mod.rs b/crates/ra_analysis/src/hir/function/mod.rs
index 8161a604f..5e44a88a7 100644
--- a/crates/ra_analysis/src/hir/function/mod.rs
+++ b/crates/ra_analysis/src/hir/function/mod.rs
@@ -42,10 +42,15 @@ impl FunctionDescriptor {
42 pub(crate) fn scope(&self, db: &impl HirDatabase) -> Arc<FnScopes> { 42 pub(crate) fn scope(&self, db: &impl HirDatabase) -> Arc<FnScopes> {
43 db.fn_scopes(self.fn_id) 43 db.fn_scopes(self.fn_id)
44 } 44 }
45
46 pub(crate) fn signature_info(&self, db: &impl HirDatabase) -> Option<FnSignatureInfo> {
47 let syntax = db.fn_syntax(self.fn_id);
48 FnSignatureInfo::new(syntax.borrowed())
49 }
45} 50}
46 51
47#[derive(Debug, Clone)] 52#[derive(Debug, Clone)]
48pub struct FnDescriptor { 53pub struct FnSignatureInfo {
49 pub name: String, 54 pub name: String,
50 pub label: String, 55 pub label: String,
51 pub ret_type: Option<String>, 56 pub ret_type: Option<String>,
@@ -53,8 +58,8 @@ pub struct FnDescriptor {
53 pub doc: Option<String>, 58 pub doc: Option<String>,
54} 59}
55 60
56impl FnDescriptor { 61impl FnSignatureInfo {
57 pub fn new(node: ast::FnDef) -> Option<Self> { 62 fn new(node: ast::FnDef) -> Option<Self> {
58 let name = node.name()?.text().to_string(); 63 let name = node.name()?.text().to_string();
59 64
60 let mut doc = None; 65 let mut doc = None;
@@ -73,7 +78,7 @@ impl FnDescriptor {
73 node.syntax().text().to_string() 78 node.syntax().text().to_string()
74 }; 79 };
75 80
76 if let Some((comment_range, docs)) = FnDescriptor::extract_doc_comments(node) { 81 if let Some((comment_range, docs)) = FnSignatureInfo::extract_doc_comments(node) {
77 let comment_range = comment_range 82 let comment_range = comment_range
78 .checked_sub(node.syntax().range().start()) 83 .checked_sub(node.syntax().range().start())
79 .unwrap(); 84 .unwrap();
@@ -105,10 +110,10 @@ impl FnDescriptor {
105 } 110 }
106 } 111 }
107 112
108 let params = FnDescriptor::param_list(node); 113 let params = FnSignatureInfo::param_list(node);
109 let ret_type = node.ret_type().map(|r| r.syntax().text().to_string()); 114 let ret_type = node.ret_type().map(|r| r.syntax().text().to_string());
110 115
111 Some(FnDescriptor { 116 Some(FnSignatureInfo {
112 name, 117 name,
113 ret_type, 118 ret_type,
114 params, 119 params,
diff --git a/crates/ra_analysis/src/hir/mod.rs b/crates/ra_analysis/src/hir/mod.rs
index 1d37fae32..5a9086cef 100644
--- a/crates/ra_analysis/src/hir/mod.rs
+++ b/crates/ra_analysis/src/hir/mod.rs
@@ -29,8 +29,7 @@ pub(crate) use self::{
29 function::{FunctionDescriptor, FnScopes}, 29 function::{FunctionDescriptor, FnScopes},
30}; 30};
31 31
32//TODO: FIXME 32pub use self::function::FnSignatureInfo;
33pub use self::function::FnDescriptor;
34 33
35pub(crate) enum Def { 34pub(crate) enum Def {
36 Module(ModuleDescriptor), 35 Module(ModuleDescriptor),