Skip to content

Commit

Permalink
pass snippet_cap to format_literal_label, return early if None
Browse files Browse the repository at this point in the history
  • Loading branch information
ntBre committed Dec 20, 2022
1 parent 1116cc9 commit 694ae77
Show file tree
Hide file tree
Showing 4 changed files with 12 additions and 5 deletions.
2 changes: 1 addition & 1 deletion crates/ide-completion/src/render/literal.rs
Original file line number Diff line number Diff line change
Expand Up @@ -96,7 +96,7 @@ fn render(
if !should_add_parens {
kind = StructKind::Unit;
}
let label = format_literal_label(&qualified_name, kind);
let label = format_literal_label(&qualified_name, kind, snippet_cap);
let lookup = if qualified {
format_literal_lookup(&short_qualified_name.to_string(), kind)
} else {
Expand Down
4 changes: 2 additions & 2 deletions crates/ide-completion/src/render/pattern.rs
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,7 @@ pub(crate) fn render_struct_pat(
let name = local_name.unwrap_or_else(|| strukt.name(ctx.db()));
let (name, escaped_name) = (name.unescaped().to_smol_str(), name.to_smol_str());
let kind = strukt.kind(ctx.db());
let label = format_literal_label(name.as_str(), kind);
let label = format_literal_label(name.as_str(), kind, ctx.snippet_cap());
let lookup = format_literal_lookup(name.as_str(), kind);
let pat = render_pat(&ctx, pattern_ctx, &escaped_name, kind, &visible_fields, fields_omitted)?;

Expand Down Expand Up @@ -67,7 +67,7 @@ pub(crate) fn render_variant_pat(
}
_ => {
let kind = variant.kind(ctx.db());
let label = format_literal_label(name.as_str(), kind);
let label = format_literal_label(name.as_str(), kind, ctx.snippet_cap());
let lookup = format_literal_lookup(name.as_str(), kind);
let pat = render_pat(
&ctx,
Expand Down
2 changes: 1 addition & 1 deletion crates/ide-completion/src/render/union_literal.rs
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ pub(crate) fn render_union_literal(
Some(p) => (p.unescaped().to_string(), p.to_string()),
None => (name.unescaped().to_string(), name.to_string()),
};
let label = format_literal_label(&name.to_smol_str(), StructKind::Record);
let label = format_literal_label(&name.to_smol_str(), StructKind::Record, ctx.snippet_cap());
let lookup = format_literal_lookup(&name.to_smol_str(), StructKind::Record);
let mut item = CompletionItem::new(
CompletionItemKind::SymbolKind(SymbolKind::Union),
Expand Down
9 changes: 8 additions & 1 deletion crates/ide-completion/src/render/variant.rs
Original file line number Diff line number Diff line change
Expand Up @@ -90,7 +90,14 @@ pub(crate) fn visible_fields(
}

/// Format a struct, etc. literal option for display in the completions menu.
pub(crate) fn format_literal_label(name: &str, kind: StructKind) -> SmolStr {
pub(crate) fn format_literal_label(
name: &str,
kind: StructKind,
snippet_cap: Option<SnippetCap>,
) -> SmolStr {
if snippet_cap.is_none() {
return name.into();
}
match kind {
StructKind::Tuple => SmolStr::from_iter([name, "(…)"]),
StructKind::Record => SmolStr::from_iter([name, " {…}"]),
Expand Down

0 comments on commit 694ae77

Please sign in to comment.