|
|
@ -230,20 +230,43 @@ impl Component for Completion {
|
|
|
|
// option.detail
|
|
|
|
// option.detail
|
|
|
|
// ---
|
|
|
|
// ---
|
|
|
|
// option.documentation
|
|
|
|
// 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 {
|
|
|
|
| Some(lsp::Documentation::MarkupContent(lsp::MarkupContent {
|
|
|
|
kind: lsp::MarkupKind::PlainText,
|
|
|
|
kind: lsp::MarkupKind::PlainText,
|
|
|
|
value: s,
|
|
|
|
value: contents,
|
|
|
|
})) => {
|
|
|
|
})) => {
|
|
|
|
// TODO: convert to wrapped text
|
|
|
|
// 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 {
|
|
|
|
Some(lsp::Documentation::MarkupContent(lsp::MarkupContent {
|
|
|
|
kind: lsp::MarkupKind::Markdown,
|
|
|
|
kind: lsp::MarkupKind::Markdown,
|
|
|
|
value: contents,
|
|
|
|
value: contents,
|
|
|
|
})) => {
|
|
|
|
})) => {
|
|
|
|
let doc = Markdown::new(contents.clone());
|
|
|
|
// 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
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// TODO: set language based on doc scope
|
|
|
|
|
|
|
|
Markdown::new(format!(
|
|
|
|
|
|
|
|
"```rust\n{}\n```",
|
|
|
|
|
|
|
|
option.detail.as_deref().unwrap_or_default(),
|
|
|
|
|
|
|
|
))
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
None => return,
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
let half = area.height / 2;
|
|
|
|
let half = area.height / 2;
|
|
|
|
let height = 15.min(half);
|
|
|
|
let height = 15.min(half);
|
|
|
|
// -2 to subtract command line + statusline. a bit of a hack, because of splits.
|
|
|
|
// -2 to subtract command line + statusline. a bit of a hack, because of splits.
|
|
|
@ -254,8 +277,5 @@ impl Component for Completion {
|
|
|
|
surface.clear_with(area, background);
|
|
|
|
surface.clear_with(area, background);
|
|
|
|
doc.render(area, surface, cx);
|
|
|
|
doc.render(area, surface, cx);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
None => (),
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|