summaryrefslogtreecommitdiff
path: root/helix-term
diff options
context:
space:
mode:
authorGokul Soumya2023-02-05 22:18:50 +0000
committerBlaž Hrastnik2023-02-11 07:05:23 +0000
commit0f844ef191af69da62c7a65b93db8a7e02cf86ff (patch)
tree2d45f5fca0ffc426cb703377bf3e79b9ebc6dddc /helix-term
parent937825e8fc415f2236c5effde7b5543f51fef542 (diff)
Refactor our Markdown construction in completion doc
Diffstat (limited to 'helix-term')
-rw-r--r--helix-term/src/ui/completion.rs40
1 files changed, 13 insertions, 27 deletions
diff --git a/helix-term/src/ui/completion.rs b/helix-term/src/ui/completion.rs
index 6263106c..7492b065 100644
--- a/helix-term/src/ui/completion.rs
+++ b/helix-term/src/ui/completion.rs
@@ -399,6 +399,16 @@ impl Component for Completion {
.expect("cursor must be in view");
let cursor_pos = coords.row as u16;
+ let markdowned = |lang: &str, detail: Option<&str>, doc: Option<&str>| {
+ let md = match (detail, doc) {
+ (Some(detail), Some(doc)) => format!("```{lang}\n{detail}\n```\n{doc}"),
+ (Some(detail), None) => format!("```{lang}\n{detail}\n```"),
+ (None, Some(doc)) => doc.to_string(),
+ (None, None) => String::new(),
+ };
+ Markdown::new(md, cx.editor.syn_loader.clone())
+ };
+
let mut markdown_doc = match &option.documentation {
Some(lsp::Documentation::String(contents))
| Some(lsp::Documentation::MarkupContent(lsp::MarkupContent {
@@ -406,42 +416,18 @@ impl Component for Completion {
value: contents,
})) => {
// TODO: convert to wrapped text
- Markdown::new(
- format!(
- "```{}\n{}\n```\n{}",
- language,
- option.detail.as_deref().unwrap_or_default(),
- contents
- ),
- cx.editor.syn_loader.clone(),
- )
+ markdowned(language, option.detail.as_deref(), Some(contents))
}
Some(lsp::Documentation::MarkupContent(lsp::MarkupContent {
kind: lsp::MarkupKind::Markdown,
value: contents,
})) => {
// TODO: set language based on doc scope
- if let Some(detail) = &option.detail.as_deref() {
- Markdown::new(
- format!("```{}\n{}\n```\n{}", language, detail, contents),
- cx.editor.syn_loader.clone(),
- )
- } else {
- Markdown::new(contents.to_string(), cx.editor.syn_loader.clone())
- }
+ markdowned(language, option.detail.as_deref(), Some(contents))
}
None if option.detail.is_some() => {
- // TODO: copied from above
-
// TODO: set language based on doc scope
- Markdown::new(
- format!(
- "```{}\n{}\n```",
- language,
- option.detail.as_deref().unwrap_or_default(),
- ),
- cx.editor.syn_loader.clone(),
- )
+ markdowned(language, option.detail.as_deref(), None)
}
None => return,
};