Unnamed repository; edit this file 'description' to name the repository.
Enable hovering function parameter inlay hints
Lukas Wirth 2022-05-19
parent 74230e2 · commit b08bbd7
-rw-r--r--crates/ide/src/inlay_hints.rs30
-rw-r--r--crates/rust-analyzer/src/to_proto.rs11
2 files changed, 28 insertions, 13 deletions
diff --git a/crates/ide/src/inlay_hints.rs b/crates/ide/src/inlay_hints.rs
index e68631f9f7..6df21e0e12 100644
--- a/crates/ide/src/inlay_hints.rs
+++ b/crates/ide/src/inlay_hints.rs
@@ -592,23 +592,35 @@ fn param_name_hints(
.filter_map(|((param, _ty), arg)| {
// Only annotate hints for expressions that exist in the original file
let range = sema.original_range_opt(arg.syntax())?;
- let (param_name, param_syntax) = match param.as_ref()? {
- Either::Left(pat) => ("self".to_string(), pat.syntax()),
+ let (param_name, name_syntax) = match param.as_ref()? {
+ Either::Left(pat) => ("self".to_string(), pat.name()),
Either::Right(pat) => match pat {
- ast::Pat::IdentPat(it) => (it.name()?.to_string(), pat.syntax()),
+ ast::Pat::IdentPat(it) => (it.name()?.to_string(), it.name()),
_ => return None,
},
};
- Some((sema.original_range_opt(param_syntax), param_name, arg, range))
+ Some((name_syntax, param_name, arg, range))
})
.filter(|(_, param_name, arg, _)| {
!should_hide_param_name_hint(sema, &callable, param_name, arg)
})
- .map(|(param_range, param_name, _, FileRange { range, .. })| InlayHint {
- range,
- kind: InlayKind::ParameterHint,
- label: param_name,
- tooltip: param_range.map(|it| InlayTooltip::HoverOffset(it.file_id, it.range.start())),
+ .map(|(param, param_name, _, FileRange { range, .. })| {
+ let mut tooltip = None;
+ if let Some(name) = param {
+ if let hir::CallableKind::Function(f) = callable.kind() {
+ // assert the file is cached so we can map out of macros
+ if let Some(_) = sema.source(f) {
+ tooltip = sema.original_range_opt(name.syntax());
+ }
+ }
+ }
+
+ InlayHint {
+ range,
+ kind: InlayKind::ParameterHint,
+ label: param_name,
+ tooltip: tooltip.map(|it| InlayTooltip::HoverOffset(it.file_id, it.range.start())),
+ }
});
acc.extend(hints);
diff --git a/crates/rust-analyzer/src/to_proto.rs b/crates/rust-analyzer/src/to_proto.rs
index 5493180c5e..f91ab6ea79 100644
--- a/crates/rust-analyzer/src/to_proto.rs
+++ b/crates/rust-analyzer/src/to_proto.rs
@@ -472,27 +472,30 @@ pub(crate) fn inlay_hint(
| InlayKind::ClosingBraceHint => None,
},
text_edits: None,
- data: match inlay_hint.tooltip {
+ data: (|| match inlay_hint.tooltip {
Some(ide::InlayTooltip::HoverOffset(file_id, offset)) => {
let uri = url(snap, file_id);
+ let line_index = snap.file_line_index(file_id).ok()?;
+
let text_document = lsp_types::TextDocumentIdentifier { uri };
to_value(lsp_ext::InlayHintResolveData {
text_document,
- position: lsp_ext::PositionOrRange::Position(position(line_index, offset)),
+ position: lsp_ext::PositionOrRange::Position(position(&line_index, offset)),
})
.ok()
}
Some(ide::InlayTooltip::HoverRanged(file_id, text_range)) => {
let uri = url(snap, file_id);
let text_document = lsp_types::TextDocumentIdentifier { uri };
+ let line_index = snap.file_line_index(file_id).ok()?;
to_value(lsp_ext::InlayHintResolveData {
text_document,
- position: lsp_ext::PositionOrRange::Range(range(line_index, text_range)),
+ position: lsp_ext::PositionOrRange::Range(range(&line_index, text_range)),
})
.ok()
}
_ => None,
- },
+ })(),
tooltip: Some(match inlay_hint.tooltip {
Some(ide::InlayTooltip::String(s)) => lsp_types::InlayHintTooltip::String(s),
_ => lsp_types::InlayHintTooltip::String(inlay_hint.label),