Skip to content

Commit b08bbd7

Browse files
committed
Enable hovering function parameter inlay hints
1 parent 74230e2 commit b08bbd7

File tree

2 files changed

+28
-13
lines changed

2 files changed

+28
-13
lines changed

crates/ide/src/inlay_hints.rs

Lines changed: 21 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -592,23 +592,35 @@ fn param_name_hints(
592592
.filter_map(|((param, _ty), arg)| {
593593
// Only annotate hints for expressions that exist in the original file
594594
let range = sema.original_range_opt(arg.syntax())?;
595-
let (param_name, param_syntax) = match param.as_ref()? {
596-
Either::Left(pat) => ("self".to_string(), pat.syntax()),
595+
let (param_name, name_syntax) = match param.as_ref()? {
596+
Either::Left(pat) => ("self".to_string(), pat.name()),
597597
Either::Right(pat) => match pat {
598-
ast::Pat::IdentPat(it) => (it.name()?.to_string(), pat.syntax()),
598+
ast::Pat::IdentPat(it) => (it.name()?.to_string(), it.name()),
599599
_ => return None,
600600
},
601601
};
602-
Some((sema.original_range_opt(param_syntax), param_name, arg, range))
602+
Some((name_syntax, param_name, arg, range))
603603
})
604604
.filter(|(_, param_name, arg, _)| {
605605
!should_hide_param_name_hint(sema, &callable, param_name, arg)
606606
})
607-
.map(|(param_range, param_name, _, FileRange { range, .. })| InlayHint {
608-
range,
609-
kind: InlayKind::ParameterHint,
610-
label: param_name,
611-
tooltip: param_range.map(|it| InlayTooltip::HoverOffset(it.file_id, it.range.start())),
607+
.map(|(param, param_name, _, FileRange { range, .. })| {
608+
let mut tooltip = None;
609+
if let Some(name) = param {
610+
if let hir::CallableKind::Function(f) = callable.kind() {
611+
// assert the file is cached so we can map out of macros
612+
if let Some(_) = sema.source(f) {
613+
tooltip = sema.original_range_opt(name.syntax());
614+
}
615+
}
616+
}
617+
618+
InlayHint {
619+
range,
620+
kind: InlayKind::ParameterHint,
621+
label: param_name,
622+
tooltip: tooltip.map(|it| InlayTooltip::HoverOffset(it.file_id, it.range.start())),
623+
}
612624
});
613625

614626
acc.extend(hints);

crates/rust-analyzer/src/to_proto.rs

Lines changed: 7 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -472,27 +472,30 @@ pub(crate) fn inlay_hint(
472472
| InlayKind::ClosingBraceHint => None,
473473
},
474474
text_edits: None,
475-
data: match inlay_hint.tooltip {
475+
data: (|| match inlay_hint.tooltip {
476476
Some(ide::InlayTooltip::HoverOffset(file_id, offset)) => {
477477
let uri = url(snap, file_id);
478+
let line_index = snap.file_line_index(file_id).ok()?;
479+
478480
let text_document = lsp_types::TextDocumentIdentifier { uri };
479481
to_value(lsp_ext::InlayHintResolveData {
480482
text_document,
481-
position: lsp_ext::PositionOrRange::Position(position(line_index, offset)),
483+
position: lsp_ext::PositionOrRange::Position(position(&line_index, offset)),
482484
})
483485
.ok()
484486
}
485487
Some(ide::InlayTooltip::HoverRanged(file_id, text_range)) => {
486488
let uri = url(snap, file_id);
487489
let text_document = lsp_types::TextDocumentIdentifier { uri };
490+
let line_index = snap.file_line_index(file_id).ok()?;
488491
to_value(lsp_ext::InlayHintResolveData {
489492
text_document,
490-
position: lsp_ext::PositionOrRange::Range(range(line_index, text_range)),
493+
position: lsp_ext::PositionOrRange::Range(range(&line_index, text_range)),
491494
})
492495
.ok()
493496
}
494497
_ => None,
495-
},
498+
})(),
496499
tooltip: Some(match inlay_hint.tooltip {
497500
Some(ide::InlayTooltip::String(s)) => lsp_types::InlayHintTooltip::String(s),
498501
_ => lsp_types::InlayHintTooltip::String(inlay_hint.label),

0 commit comments

Comments
 (0)