Show macro_rules snippet in blocks

This commit is contained in:
Jonas Schievink 2022-04-27 14:40:09 +02:00
parent 0b49c93b91
commit 0060d5977d
2 changed files with 27 additions and 20 deletions

View file

@ -43,7 +43,7 @@ pub(crate) fn complete_expr_snippet(acc: &mut Completions, ctx: &CompletionConte
}
pub(crate) fn complete_item_snippet(acc: &mut Completions, ctx: &CompletionContext) {
if !ctx.expects_item()
if !(ctx.expects_item() || ctx.has_block_expr_parent())
|| ctx.previous_token_is(T![unsafe])
|| ctx.path_qual().is_some()
|| ctx.has_impl_or_trait_prev_sibling()
@ -63,6 +63,8 @@ pub(crate) fn complete_item_snippet(acc: &mut Completions, ctx: &CompletionConte
add_custom_completions(acc, ctx, cap, SnippetScope::Item);
}
// Test-related snippets shouldn't be shown in blocks.
if !ctx.has_block_expr_parent() {
let mut item = snippet(
ctx,
cap,
@ -93,6 +95,7 @@ fn ${1:feature}() {
);
item.lookup_by("tfn");
item.add_to(acc);
}
let item = snippet(
ctx,

View file

@ -153,6 +153,7 @@ impl Unit {
kw return
sn pd
sn ppd
sn macro_rules
kw self
kw super
kw crate
@ -246,6 +247,7 @@ fn complete_in_block() {
kw return
sn pd
sn ppd
sn macro_rules
kw self
kw super
kw crate
@ -293,6 +295,7 @@ fn complete_after_if_expr() {
kw return
sn pd
sn ppd
sn macro_rules
kw self
kw super
kw crate
@ -366,6 +369,7 @@ fn completes_in_loop_ctx() {
kw return
sn pd
sn ppd
sn macro_rules
kw self
kw super
kw crate