From 4806a6066ce2b0b0b99a230aa52ea4e723ca4d72 Mon Sep 17 00:00:00 2001 From: Paul Dingemans Date: Tue, 16 Jul 2024 15:47:56 +0200 Subject: [PATCH] Suppress `backing-property-naming` on `@Suppress(`PropertyName`)` Closes #2714 --- .../engine/internal/SuppressionLocator.kt | 34 +++++++++---------- .../rules/BackingPropertyNamingRuleTest.kt | 4 +-- .../standard/rules/PropertyNamingRuleTest.kt | 2 +- 3 files changed, 20 insertions(+), 20 deletions(-) diff --git a/ktlint-rule-engine/src/main/kotlin/com/pinterest/ktlint/rule/engine/internal/SuppressionLocator.kt b/ktlint-rule-engine/src/main/kotlin/com/pinterest/ktlint/rule/engine/internal/SuppressionLocator.kt index 5040d64481..5fa7a31ba8 100644 --- a/ktlint-rule-engine/src/main/kotlin/com/pinterest/ktlint/rule/engine/internal/SuppressionLocator.kt +++ b/ktlint-rule-engine/src/main/kotlin/com/pinterest/ktlint/rule/engine/internal/SuppressionLocator.kt @@ -17,7 +17,7 @@ import org.jetbrains.kotlin.psi.psiUtil.endOffset import org.jetbrains.kotlin.psi.psiUtil.startOffset internal class SuppressionLocator( - private val editorConfig: EditorConfig, + editorConfig: EditorConfig, ) { private val formatterTags = FormatterTags.from(editorConfig) @@ -181,7 +181,7 @@ internal class SuppressionLocator( ?.constructorReferenceExpression ?.getReferencedName() in SUPPRESS_ANNOTATIONS }.flatMap(KtAnnotationEntry::getValueArguments) - .mapNotNull { it.toRuleId(SUPPRESS_ANNOTATION_RULE_MAP) } + .flatMap { it.findRuleSuppressionIds() } .let { suppressedRuleIds -> when { suppressedRuleIds.isEmpty() -> null @@ -200,7 +200,7 @@ internal class SuppressionLocator( } } - private fun ValueArgument.toRuleId(annotationValueToRuleMapping: Map): String? = + private fun ValueArgument.findRuleSuppressionIds(): List = getArgumentExpression() ?.text ?.removeSurrounding("\"") @@ -208,7 +208,7 @@ internal class SuppressionLocator( when { argumentExpressionText == "ktlint" -> { // Disable all rules - ALL_KTLINT_RULES_SUPPRESSION_ID + listOf(ALL_KTLINT_RULES_SUPPRESSION_ID) } argumentExpressionText.startsWith("ktlint:") -> { @@ -217,15 +217,15 @@ internal class SuppressionLocator( // code bases in which the rule and suppression id's have not yet been fixed. argumentExpressionText .removePrefix("ktlint:") - .let { RuleId.prefixWithStandardRuleSetIdWhenMissing(it) } + .let { listOf(RuleId.prefixWithStandardRuleSetIdWhenMissing(it)) } } else -> { // Disable specific rule if the annotation value is mapped to a specific rule - annotationValueToRuleMapping[argumentExpressionText] + SUPPRESS_ANNOTATION_RULE_MAP[argumentExpressionText] } } - } + }.orEmpty() /** * @param range zero-based range of lines where lint errors should be suppressed @@ -257,16 +257,16 @@ internal class SuppressionLocator( mapOf( // It would have been nice if the official rule id's as defined in the Rules themselves could have been used here. But that // would introduce a circular dependency between the ktlint-rule-engine and the ktlint-ruleset-standard modules. - "EnumEntryName" to "standard:enum-entry-name-case", - "RemoveCurlyBracesFromTemplate" to "standard:string-template", - "ClassName" to "standard:class-naming", - "FunctionName" to "standard:function-naming", - "PackageName" to "standard:package-name", - "PropertyName" to "standard:property-naming", - "ConstPropertyName" to "standard:property-naming", - "ObjectPropertyName" to "standard:property-naming", - "PrivatePropertyName" to "standard:property-naming", - "UnusedImport" to "standard:no-unused-imports", + "EnumEntryName" to listOf("standard:enum-entry-name-case"), + "RemoveCurlyBracesFromTemplate" to listOf("standard:string-template"), + "ClassName" to listOf("standard:class-naming"), + "FunctionName" to listOf("standard:function-naming"), + "PackageName" to listOf("standard:package-name"), + "PropertyName" to listOf("standard:property-naming", "standard:backing-property-naming"), + "ConstPropertyName" to listOf("standard:property-naming"), + "ObjectPropertyName" to listOf("standard:property-naming"), + "PrivatePropertyName" to listOf("standard:property-naming"), + "UnusedImport" to listOf("standard:no-unused-imports"), ) val SUPPRESS_ANNOTATIONS = setOf("Suppress", "SuppressWarnings") const val ALL_KTLINT_RULES_SUPPRESSION_ID = "ktlint:suppress-all-rules" 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 f6d3eaeb20..de5207895d 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 @@ -279,11 +279,11 @@ class BackingPropertyNamingRuleTest { "PropertyName", // IntelliJ IDEA suppression ], ) - fun `Given class with a disallowed name which is suppressed`(suppressionName: String) { + fun `Given a property with a disallowed name which is suppressed`(suppressionName: String) { val code = """ @Suppress("$suppressionName") - val foo = Foo() + val _foo = Foo() """.trimIndent() backingPropertyNamingRuleAssertThat(code).hasNoLintViolations() } diff --git a/ktlint-ruleset-standard/src/test/kotlin/com/pinterest/ktlint/ruleset/standard/rules/PropertyNamingRuleTest.kt b/ktlint-ruleset-standard/src/test/kotlin/com/pinterest/ktlint/ruleset/standard/rules/PropertyNamingRuleTest.kt index db7aa7b26e..a0601ec530 100644 --- a/ktlint-ruleset-standard/src/test/kotlin/com/pinterest/ktlint/ruleset/standard/rules/PropertyNamingRuleTest.kt +++ b/ktlint-ruleset-standard/src/test/kotlin/com/pinterest/ktlint/ruleset/standard/rules/PropertyNamingRuleTest.kt @@ -144,7 +144,7 @@ class PropertyNamingRuleTest { "PropertyName", // IntelliJ IDEA suppression ], ) - fun `Given a function with a disallowed name which is suppressed`(suppressionName: String) { + fun `Given a property with a disallowed name which is suppressed`(suppressionName: String) { val code = """ @Suppress("$suppressionName")