From 4bb758da98dd64d2807da0a0d5849e47d2b86e7f Mon Sep 17 00:00:00 2001 From: Jesse Wilson Date: Wed, 20 Nov 2024 14:12:39 -0500 Subject: [PATCH] Attempt to canonicalize enum constants (#70) * Attempt to canonicalize enum constants * Just use the owner name --------- Co-authored-by: Jesse Wilson --- .../src/main/kotlin/app/cash/burst/kotlin/Argument.kt | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/burst-kotlin-plugin/src/main/kotlin/app/cash/burst/kotlin/Argument.kt b/burst-kotlin-plugin/src/main/kotlin/app/cash/burst/kotlin/Argument.kt index 3aaeb2a..6dd21bd 100644 --- a/burst-kotlin-plugin/src/main/kotlin/app/cash/burst/kotlin/Argument.kt +++ b/burst-kotlin-plugin/src/main/kotlin/app/cash/burst/kotlin/Argument.kt @@ -210,10 +210,10 @@ private fun enumValueArguments( ): List { val enumEntries = referenceClass.declarations.filterIsInstance() val hasDefaultValue = parameter.defaultValue != null - val defaultEnumSymbol = parameter.defaultValue?.let { defaultValue -> + val defaultEnumSymbolName = parameter.defaultValue?.let { defaultValue -> val expression = defaultValue.expression when { - expression is IrGetEnumValue -> expression.symbol + expression is IrGetEnumValue -> expression.symbol.owner.name expression is IrConst<*> && expression.value == null -> null else -> unexpectedDefaultValue(parameter) } @@ -225,7 +225,7 @@ private fun enumValueArguments( EnumValueArgument( original = parameter, type = parameter.type, - isDefault = hasDefaultValue && enumEntry.symbol == defaultEnumSymbol, + isDefault = hasDefaultValue && enumEntry.symbol.owner.name == defaultEnumSymbolName, value = enumEntry, ), ) @@ -235,7 +235,7 @@ private fun enumValueArguments( NullArgument( original = parameter, type = parameter.type, - isDefault = hasDefaultValue && defaultEnumSymbol == null, + isDefault = hasDefaultValue && defaultEnumSymbolName == null, ), ) }