Skip to content

Commit

Permalink
Support virtual path in DiktatProcessor (#1874)
Browse files Browse the repository at this point in the history
  • Loading branch information
nulls authored Dec 18, 2023
1 parent b3cd098 commit beb9960
Show file tree
Hide file tree
Showing 6 changed files with 28 additions and 21 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -20,13 +20,13 @@ interface DiktatProcessor {
* Run `diktat fix` on provided [code] using [callback] for detected errors and returned formatted code.
*
* @param code
* @param isScript
* @param virtualPath a path which should be taken into account in processing of [code]
* @param callback
* @return result of `diktat fix`
*/
fun fix(
code: String,
isScript: Boolean,
virtualPath: Path?,
callback: DiktatCallback,
): String

Expand All @@ -42,12 +42,12 @@ interface DiktatProcessor {
* Run `diktat check` on provided [code] using [callback] for detected errors.
*
* @param code
* @param isScript
* @param virtualPath a path which should be taken into account in processing of [code]
* @param callback
*/
fun check(
code: String,
isScript: Boolean,
virtualPath: Path?,
callback: DiktatCallback,
)
}
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@ import org.ec4j.core.model.Glob
import org.ec4j.core.model.Property
import org.ec4j.core.model.PropertyType
import java.nio.file.Path
import kotlin.io.path.name

private typealias LintCallback = (LintError) -> Unit

Expand All @@ -30,18 +31,18 @@ class DiktatProcessorFactoryImpl : DiktatProcessorFactory {
): String = ktLintRuleEngine.formatSilentlyThenLint(file.toKtLint(), callback.toKtLintForLint())
override fun fix(
code: String,
isScript: Boolean,
virtualPath: Path?,
callback: DiktatCallback
): String = ktLintRuleEngine.formatSilentlyThenLint(code.toKtLint(isScript), callback.toKtLintForLint())
): String = ktLintRuleEngine.formatSilentlyThenLint(code.toKtLint(virtualPath), callback.toKtLintForLint())
override fun check(
file: Path,
callback: DiktatCallback,
) = ktLintRuleEngine.lint(file.toKtLint(), callback.toKtLintForLint())
override fun check(
code: String,
isScript: Boolean,
virtualPath: Path?,
callback: DiktatCallback
) = ktLintRuleEngine.lint(code.toKtLint(isScript), callback.toKtLintForLint())
) = ktLintRuleEngine.lint(code.toKtLint(virtualPath), callback.toKtLintForLint())
}
}

Expand All @@ -66,7 +67,13 @@ class DiktatProcessorFactoryImpl : DiktatProcessorFactory {

private fun Path.toKtLint(): Code = Code.fromFile(this.toFile())

private fun String.toKtLint(isScript: Boolean): Code = Code.fromSnippet(this, isScript)
private fun String.toKtLint(virtualPath: Path?): Code = Code(
content = this,
fileName = virtualPath?.name,
filePath = virtualPath,
script = virtualPath?.name?.endsWith(".kts", ignoreCase = true) ?: false,
isStdIn = virtualPath == null,
)

private fun DiktatCallback.toKtLintForLint(): LintCallback = { error ->
this(error.wrap(), false)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -158,10 +158,10 @@ fun format(
* @param ruleSetSupplier
* @param file
* @param cb callback to be called on unhandled [LintError]s
* @return formatted code
* @return [Unit]
*/
@Suppress("LAMBDA_IS_NOT_LAST_PARAMETER")
fun lint(
fun check(
ruleSetSupplier: () -> DiktatRuleSet,
file: Path,
cb: DiktatCallback = DiktatCallback.empty
Expand All @@ -175,16 +175,16 @@ fun lint(
* @param ruleSetSupplier
* @param text
* @param cb callback to be called on unhandled [LintError]s
* @return formatted code
* @return [Unit]
*/
@Suppress("LAMBDA_IS_NOT_LAST_PARAMETER")
fun lint(
fun check(
ruleSetSupplier: () -> DiktatRuleSet,
@Language("kotlin") text: String,
cb: DiktatCallback = DiktatCallback.empty
) = DiktatProcessorFactoryImpl().invoke(ruleSetSupplier())
.check(
code = text,
isScript = false,
virtualPath = null,
callback = cb.ignoreCorrectedErrors(),
)
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ package com.saveourtool.diktat.ruleset.utils
import com.saveourtool.diktat.api.DiktatErrorEmitter
import com.saveourtool.diktat.api.DiktatRule
import com.saveourtool.diktat.api.DiktatRuleSet
import com.saveourtool.diktat.ktlint.lint
import com.saveourtool.diktat.ktlint.check
import com.saveourtool.diktat.util.applyToCode

import org.jetbrains.kotlin.KtNodeTypes
Expand Down Expand Up @@ -809,7 +809,7 @@ private class PrettyPrintingVisitor(private val elementType: IElementType,
maxLevel: Int = -1,
expected: String
) {
lint(
check(
ruleSetSupplier = { DiktatRuleSet(listOf(PrettyPrintingVisitor(elementType, level, maxLevel, expected))) },
text = code,
)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ package com.saveourtool.diktat.util

import com.saveourtool.diktat.api.DiktatCallback
import com.saveourtool.diktat.common.config.rules.RulesConfig
import com.saveourtool.diktat.ktlint.lint
import com.saveourtool.diktat.ktlint.check
import com.saveourtool.diktat.ruleset.rules.DiktatRule
import com.saveourtool.diktat.util.DiktatRuleSetFactoryImplTest.Companion.diktatRuleSetForTest
import com.saveourtool.diktat.api.DiktatError
Expand Down Expand Up @@ -127,7 +127,7 @@ open class LintTestBase(private val ruleSupplier: (rulesConfigList: List<RulesCo
): List<DiktatError> {
val lintErrors: MutableList<DiktatError> = mutableListOf()

lint(
check(
ruleSetSupplier = { rulesConfigList.toDiktatRuleSet() },
file = file,
cb = lintErrors.collector(),
Expand All @@ -151,7 +151,7 @@ open class LintTestBase(private val ruleSupplier: (rulesConfigList: List<RulesCo
): List<DiktatError> {
val lintErrors: MutableList<DiktatError> = mutableListOf()

lint(
check(
ruleSetSupplier = { rulesConfigList.toDiktatRuleSet() },
text = code,
cb = lintErrors.collector(),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ package com.saveourtool.diktat.util
import com.saveourtool.diktat.api.DiktatErrorEmitter
import com.saveourtool.diktat.api.DiktatRule
import com.saveourtool.diktat.api.DiktatRuleSet
import com.saveourtool.diktat.ktlint.lint
import com.saveourtool.diktat.ktlint.check

import org.assertj.core.api.Assertions.assertThat
import org.assertj.core.api.Assertions.fail
Expand Down Expand Up @@ -111,7 +111,7 @@ internal fun applyToCode(@Language("kotlin") code: String,
applyToNode: (node: ASTNode, counter: AtomicInteger) -> Unit
) {
val counter = AtomicInteger(0)
lint(
check(
ruleSetSupplier = {
DiktatRuleSet(listOf(object : DiktatRule {
override val id: String
Expand Down

0 comments on commit beb9960

Please sign in to comment.