Completion: Render non-markdown docs too

imgbot
Blaž Hrastnik 3 years ago
parent 2c48d65b15
commit 3810650a6b

@ -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 => (),
}
}
} }
} }

Loading…
Cancel
Save