![JAR search and dependency download from the Maven repository](/logo.png)
io.gitlab.arturbosch.detekt.rules.style.UseRequire.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of detekt-rules-style Show documentation
Show all versions of detekt-rules-style Show documentation
Static code analysis for Kotlin
The newest version!
package io.gitlab.arturbosch.detekt.rules.style
import io.gitlab.arturbosch.detekt.api.CodeSmell
import io.gitlab.arturbosch.detekt.api.Config
import io.gitlab.arturbosch.detekt.api.Debt
import io.gitlab.arturbosch.detekt.api.Entity
import io.gitlab.arturbosch.detekt.api.Issue
import io.gitlab.arturbosch.detekt.api.Rule
import io.gitlab.arturbosch.detekt.api.Severity
import io.gitlab.arturbosch.detekt.api.internal.ActiveByDefault
import io.gitlab.arturbosch.detekt.rules.arguments
import io.gitlab.arturbosch.detekt.rules.isEmptyOrSingleStringArgument
import io.gitlab.arturbosch.detekt.rules.isEnclosedByConditionalStatement
import io.gitlab.arturbosch.detekt.rules.isIllegalArgumentException
import org.jetbrains.kotlin.psi.KtBlockExpression
import org.jetbrains.kotlin.psi.KtThrowExpression
/**
* Kotlin provides a much more concise way to check preconditions than to manually throw an
* IllegalArgumentException.
*
*
* if (value == null) throw IllegalArgumentException("value should not be null")
* if (value < 0) throw IllegalArgumentException("value is $value but should be at least 0")
*
*
*
* requireNotNull(value) { "value should not be null" }
* require(value >= 0) { "value is $value but should be at least 0" }
*
*/
@Suppress("ViolatesTypeResolutionRequirements")
@ActiveByDefault(since = "1.21.0")
class UseRequire(config: Config = Config.empty) : Rule(config) {
override val issue = Issue(
"UseRequire",
Severity.Style,
"Use require() instead of throwing an IllegalArgumentException.",
Debt.FIVE_MINS
)
override fun visitThrowExpression(expression: KtThrowExpression) {
if (!expression.isIllegalArgumentException()) return
if (expression.hasMoreExpressionsInBlock()) return
if (expression.isEnclosedByConditionalStatement() &&
expression.arguments.isEmptyOrSingleStringArgument(bindingContext)
) {
report(CodeSmell(issue, Entity.from(expression), issue.description))
}
}
private fun KtThrowExpression.hasMoreExpressionsInBlock(): Boolean =
(parent as? KtBlockExpression)?.run { statements.size > 1 } ?: false
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy