aboutsummaryrefslogtreecommitdiff
path: root/helix-term/src/ui/completion.rs
diff options
context:
space:
mode:
Diffstat (limited to 'helix-term/src/ui/completion.rs')
-rw-r--r--helix-term/src/ui/completion.rs50
1 files changed, 35 insertions, 15 deletions
diff --git a/helix-term/src/ui/completion.rs b/helix-term/src/ui/completion.rs
index a757406b..a75a4d6c 100644
--- a/helix-term/src/ui/completion.rs
+++ b/helix-term/src/ui/completion.rs
@@ -230,32 +230,52 @@ impl Component for Completion {
// option.detail
// ---
// option.documentation
- match &option.documentation {
- Some(lsp::Documentation::String(s))
+
+ let doc = match &option.documentation {
+ Some(lsp::Documentation::String(contents))
| Some(lsp::Documentation::MarkupContent(lsp::MarkupContent {
kind: lsp::MarkupKind::PlainText,
- value: s,
+ value: contents,
})) => {
// TODO: convert to wrapped text
- let doc = s;
+ Markdown::new(format!(
+ "```rust\n{}\n```\n{}",
+ option.detail.as_deref().unwrap_or_default(),
+ contents.clone()
+ ))
}
Some(lsp::Documentation::MarkupContent(lsp::MarkupContent {
kind: lsp::MarkupKind::Markdown,
value: contents,
})) => {
- let doc = Markdown::new(contents.clone());
- let half = area.height / 2;
- let height = 15.min(half);
- // -2 to subtract command line + statusline. a bit of a hack, because of splits.
- let area = Rect::new(0, area.height - height - 2, area.width, height);
+ // TODO: set language based on doc scope
+ Markdown::new(format!(
+ "```rust\n{}\n```\n{}",
+ option.detail.as_deref().unwrap_or_default(),
+ contents.clone()
+ ))
+ }
+ None if option.detail.is_some() => {
+ // TODO: copied from above
- // clear area
- let background = cx.editor.theme.get("ui.popup");
- surface.clear_with(area, background);
- doc.render(area, surface, cx);
+ // TODO: set language based on doc scope
+ Markdown::new(format!(
+ "```rust\n{}\n```",
+ option.detail.as_deref().unwrap_or_default(),
+ ))
}
- None => (),
- }
+ None => return,
+ };
+
+ let half = area.height / 2;
+ let height = 15.min(half);
+ // -2 to subtract command line + statusline. a bit of a hack, because of splits.
+ let area = Rect::new(0, area.height - height - 2, area.width, height);
+
+ // clear area
+ let background = cx.editor.theme.get("ui.popup");
+ surface.clear_with(area, background);
+ doc.render(area, surface, cx);
}
}
}