From b7c3731e816b6fc7c029aca39ea6da94a6322a4b Mon Sep 17 00:00:00 2001 From: Paul Dingemans Date: Tue, 23 Jul 2024 12:50:24 +0200 Subject: [PATCH] Ignore properties starting with `_` in `backing-property-naming` rule Name of an overridden property can only be changed by changing the name of the base property. Closes #2748 --- .../standard/rules/BackingPropertyNamingRule.kt | 6 +++++- .../rules/BackingPropertyNamingRuleTest.kt | 14 ++++++++++++++ 2 files changed, 19 insertions(+), 1 deletion(-) diff --git a/ktlint-ruleset-standard/src/main/kotlin/com/pinterest/ktlint/ruleset/standard/rules/BackingPropertyNamingRule.kt b/ktlint-ruleset-standard/src/main/kotlin/com/pinterest/ktlint/ruleset/standard/rules/BackingPropertyNamingRule.kt index cc81eda298..ce6118bb44 100644 --- a/ktlint-ruleset-standard/src/main/kotlin/com/pinterest/ktlint/ruleset/standard/rules/BackingPropertyNamingRule.kt +++ b/ktlint-ruleset-standard/src/main/kotlin/com/pinterest/ktlint/ruleset/standard/rules/BackingPropertyNamingRule.kt @@ -4,6 +4,7 @@ import com.pinterest.ktlint.rule.engine.core.api.AutocorrectDecision import com.pinterest.ktlint.rule.engine.core.api.ElementType.FUN import com.pinterest.ktlint.rule.engine.core.api.ElementType.IDENTIFIER import com.pinterest.ktlint.rule.engine.core.api.ElementType.INTERNAL_KEYWORD +import com.pinterest.ktlint.rule.engine.core.api.ElementType.OVERRIDE_KEYWORD import com.pinterest.ktlint.rule.engine.core.api.ElementType.PRIVATE_KEYWORD import com.pinterest.ktlint.rule.engine.core.api.ElementType.PROPERTY import com.pinterest.ktlint.rule.engine.core.api.ElementType.PROTECTED_KEYWORD @@ -53,7 +54,10 @@ public class BackingPropertyNamingRule : property .findChildByType(IDENTIFIER) ?.takeIf { it.text.startsWith("_") } - ?.let { identifier -> + ?.takeUnless { + // Do not report overridden properties as they can only be changed by changing the base property + it.treeParent.hasModifier(OVERRIDE_KEYWORD) + }?.let { identifier -> visitBackingProperty(identifier, emit) } } diff --git a/ktlint-ruleset-standard/src/test/kotlin/com/pinterest/ktlint/ruleset/standard/rules/BackingPropertyNamingRuleTest.kt b/ktlint-ruleset-standard/src/test/kotlin/com/pinterest/ktlint/ruleset/standard/rules/BackingPropertyNamingRuleTest.kt index de5207895d..285588abbf 100644 --- a/ktlint-ruleset-standard/src/test/kotlin/com/pinterest/ktlint/ruleset/standard/rules/BackingPropertyNamingRuleTest.kt +++ b/ktlint-ruleset-standard/src/test/kotlin/com/pinterest/ktlint/ruleset/standard/rules/BackingPropertyNamingRuleTest.kt @@ -344,4 +344,18 @@ class BackingPropertyNamingRuleTest { """.trimIndent() backingPropertyNamingRuleAssertThat(code).hasNoLintViolations() } + + @Test + fun `Issue 2748 - Given an override property with name starting with '_' then do not report a violation`() { + val code = + """ + // The property "__foo" in example below can be defined in an external dependency, which can not be changed. Even in case it is + // a (internal) dependency that can be changed, the violation should only be reported at the base property, but on the overrides + val fooBar = + object : FooBar { + override val __foo = "foo" + } + """.trimIndent() + backingPropertyNamingRuleAssertThat(code).hasNoLintViolations() + } }