//! Completes constants and paths in unqualified patterns.
+use hir::db::DefDatabase;
+
use crate::{
context::{PatternContext, PatternRefutability},
CompletionContext, Completions,
}
_ => return,
};
+ let single_variant_enum = |enum_: hir::Enum| ctx.db.enum_data(enum_.into()).variants.len() == 1;
- if refutable {
- if let Some(hir::Adt::Enum(e)) =
- ctx.expected_type.as_ref().and_then(|ty| ty.strip_references().as_adt())
- {
+ if let Some(hir::Adt::Enum(e)) =
+ ctx.expected_type.as_ref().and_then(|ty| ty.strip_references().as_adt())
+ {
+ if refutable || single_variant_enum(e) {
super::enum_variants_with_paths(acc, ctx, e, |acc, ctx, variant, path| {
acc.add_qualified_variant_pat(ctx, variant, path.clone());
acc.add_qualified_enum_variant(ctx, variant, path);
// FIXME: ideally, we should look at the type we are matching against and
// suggest variants + auto-imports
ctx.process_all_names(&mut |name, res| {
- let add_resolution = match &res {
+ let add_resolution = match res {
hir::ScopeDef::ModuleDef(def) => match def {
hir::ModuleDef::Adt(hir::Adt::Struct(strukt)) => {
- acc.add_struct_pat(ctx, *strukt, Some(name.clone()));
+ acc.add_struct_pat(ctx, strukt, Some(name.clone()));
true
}
- hir::ModuleDef::Variant(variant) if refutable => {
- acc.add_variant_pat(ctx, *variant, Some(name.clone()));
+ hir::ModuleDef::Variant(variant)
+ if refutable || single_variant_enum(variant.parent_enum(ctx.db)) =>
+ {
+ acc.add_variant_pat(ctx, variant, Some(name.clone()));
true
}
- hir::ModuleDef::Adt(hir::Adt::Enum(..))
- | hir::ModuleDef::Variant(..)
- | hir::ModuleDef::Const(..)
- | hir::ModuleDef::Module(..) => refutable,
+ hir::ModuleDef::Adt(hir::Adt::Enum(e)) => refutable || single_variant_enum(e),
+ hir::ModuleDef::Const(..) | hir::ModuleDef::Module(..) => refutable,
_ => false,
},
hir::ScopeDef::MacroDef(mac) => mac.is_fn_like(),