From 1f17c5376959fcfe86ff35a32649150a10b6bf55 Mon Sep 17 00:00:00 2001 From: Nikita Klimenko Date: Wed, 7 Aug 2024 15:16:55 +0300 Subject: [PATCH] [Compiler plugin] silently abort interpretation in case of invariant errors --- .../kotlinx/dataframe/plugin/interpret.kt | 32 +++++++++++-------- 1 file changed, 19 insertions(+), 13 deletions(-) diff --git a/plugins/kotlin-dataframe/src/org/jetbrains/kotlinx/dataframe/plugin/interpret.kt b/plugins/kotlin-dataframe/src/org/jetbrains/kotlinx/dataframe/plugin/interpret.kt index c1de464a02..d69f0ef027 100644 --- a/plugins/kotlin-dataframe/src/org/jetbrains/kotlinx/dataframe/plugin/interpret.kt +++ b/plugins/kotlin-dataframe/src/org/jetbrains/kotlinx/dataframe/plugin/interpret.kt @@ -90,32 +90,38 @@ fun KotlinTypeFacade.interpret( val defaultArguments = processor.expectedArguments.filter { it.defaultValue is Present }.map { it.name }.toSet() val actualArgsMap = refinedArguments.associateBy { it.name.identifier }.toSortedMap() val conflictingKeys = additionalArguments.keys intersect actualArgsMap.keys - if (conflictingKeys.isNotEmpty() && isTest) { - interpretationFrameworkError("Conflicting keys: $conflictingKeys") + if (conflictingKeys.isNotEmpty()) { + if (isTest) { + interpretationFrameworkError("Conflicting keys: $conflictingKeys") + } + return null } val expectedArgsMap = processor.expectedArguments .filterNot { it.name.startsWith("typeArg") } .associateBy { it.name }.toSortedMap().minus(additionalArguments.keys) val unexpectedArguments = expectedArgsMap.keys - defaultArguments != actualArgsMap.keys - defaultArguments - if (unexpectedArguments && isTest) { - val message = buildString { - appendLine("ERROR: Different set of arguments") - appendLine("Implementation class: $processor") - appendLine("Not found in actual: ${expectedArgsMap.keys - actualArgsMap.keys}") - val diff = actualArgsMap.keys - expectedArgsMap.keys - appendLine("Passed, but not expected: ${diff}") - appendLine("add arguments to an interpeter:") - appendLine(diff.map { actualArgsMap[it] }) + if (unexpectedArguments) { + if (isTest) { + val message = buildString { + appendLine("ERROR: Different set of arguments") + appendLine("Implementation class: $processor") + appendLine("Not found in actual: ${expectedArgsMap.keys - actualArgsMap.keys}") + val diff = actualArgsMap.keys - expectedArgsMap.keys + appendLine("Passed, but not expected: ${diff}") + appendLine("add arguments to an interpeter:") + appendLine(diff.map { actualArgsMap[it] }) + } + interpretationFrameworkError(message) } - interpretationFrameworkError(message) + return null } val arguments = mutableMapOf>() arguments += additionalArguments val interpretationResults = refinedArguments.refinedArguments.mapNotNull { val name = it.name.identifier - val expectedArgument = expectedArgsMap[name]!! + val expectedArgument = expectedArgsMap[name] ?: error("$processor $name") val expectedReturnType = expectedArgument.klass val value: Interpreter.Success? = when (expectedArgument.lens) { is Interpreter.Value -> {