Suppressing Issues
detekt supports the Java (@SuppressWarnings
) and Kotlin (@Suppress
) style suppression.
If both annotations are present, Kotlin's annotation is favored!
To suppress an issue, the id of the rule must be written inside the values field of the annotation (e.g. @Suppress("LongMethod")
).
If a LargeClass
is reported, but that is totally fine for you codebase, then just annotate it:
@Suppress("LargeClass") // or use complexity.LargeClass
object Constants {
...
}
It is also possible to prefix the rule id with detekt
and/or the ruleset id such as @Suppress("detekt:LongMethod")
or @Suppress("complexity:LongParameterList")
.
The following table shows the various supported suppression formats.
Example Suppression | Description |
---|---|
all , detekt:all , detekt.all | Suppresses all detekt findings. |
style , detekt:style , detekt.style | Suppresses all findings from rules in the style rule set. |
MagicNumber , style:MagicNumber , style.MagicNumber , detekt:style:MagicNumber , detekt.style.MagicNumber | Suppresses all MagicNumber rule findings. |
Some rules like TooManyFunctions
can only be suppressed by using a file level annotation @file:Suppress("TooManyFunctions")
.
Formatting rules suppression
Please note that rules inside the formatting
ruleset can only be suppressed at the file level.
Rules inside this ruleset are wrappers around KtLint rules, and we don't have the same reporting capabilities that we offer for first party rules. For example, you can suppress the MaximumLineLength rule only in your entire file with:
@file:Suppress("MaximumLineLength")
package com.example
object AClassWithLongLines {
//...
}
Several rules in the formatting
ruleset also have a "first party" counterpart. For instance you can use the MaxLineLength
rule instead from the style
ruleset.
For those rules, you can suppress the inspection also locally (on top of an expression, function, class, etc.).