From 0ed85beb15abac72cde1a3e83ef8f1122d6dea8c Mon Sep 17 00:00:00 2001 From: Amos Wenger Date: Sat, 21 May 2022 01:36:26 +0200 Subject: [PATCH] Don't suggest enum variant if name_ref start with ASCII lowercase letter --- .../src/handlers/generate_enum_variant.rs | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/crates/ide-assists/src/handlers/generate_enum_variant.rs b/crates/ide-assists/src/handlers/generate_enum_variant.rs index 8780036493..c68b587ad1 100644 --- a/crates/ide-assists/src/handlers/generate_enum_variant.rs +++ b/crates/ide-assists/src/handlers/generate_enum_variant.rs @@ -41,6 +41,10 @@ pub(crate) fn generate_enum_variant(acc: &mut Assists, ctx: &AssistContext) -> O } let name_ref = path.segment()?.name_ref()?; + if name_ref.text().as_str().chars().next()?.is_ascii_lowercase() { + // No need to generate anything if the name starts with a lowercase letter + return None; + } if let Some(hir::PathResolution::Def(hir::ModuleDef::Adt(hir::Adt::Enum(e)))) = ctx.sema.resolve_path(&path.qualifier()?) @@ -146,6 +150,21 @@ fn main() { ) } + #[test] + fn not_applicable_for_lowercase() { + check_assist_not_applicable( + generate_enum_variant, + r" +enum Foo { + Bar, +} +fn main() { + Foo::new$0 +} +", + ) + } + #[test] fn indentation_level_is_correct() { check_assist(