main.seskar.compiler.union.backend.JsUnion.kt Maven / Gradle / Ivy
package seskar.compiler.union.backend
import org.jetbrains.kotlin.descriptors.ClassKind
import org.jetbrains.kotlin.ir.declarations.IrClass
import org.jetbrains.kotlin.ir.declarations.IrEnumEntry
import org.jetbrains.kotlin.ir.expressions.IrConst
import org.jetbrains.kotlin.ir.expressions.IrConstructorCall
import org.jetbrains.kotlin.ir.expressions.IrGetEnumValue
import org.jetbrains.kotlin.ir.util.getAnnotation
import org.jetbrains.kotlin.name.FqName
private val JS_UNION = FqName("seskar.js.JsUnion")
private val JS_INT = FqName("seskar.js.JsInt")
private val JS_STRING = FqName("seskar.js.JsString")
private fun jsValue(i: Int): String = "$i"
private fun jsValue(s: String): String = "'$s'"
private val IrEnumEntry.id: String
get() = name.identifier
private inline fun IrConstructorCall.value(): T {
val argument = getValueArgument(0) as IrConst<*>
return argument.value as T
}
private fun IrEnumEntry.value(case: Case): String {
val jsInt = getAnnotation(JS_INT)
if (jsInt != null) {
return jsValue(jsInt.value())
}
val jsString = getAnnotation(JS_STRING)
if (jsString != null) {
return jsValue(jsString.value())
}
return jsValue(id.toCase(case))
}
internal fun IrClass.toJsUnionBody(): String? {
if (!isExternal)
return null
if (kind != ClassKind.ENUM_CLASS)
return null
val jsUnion = getAnnotation(JS_UNION)
?: return null
val entry = jsUnion.getValueArgument(0) as IrGetEnumValue?
val case = if (entry != null) {
Case.valueOf(entry.symbol.owner.name.identifier)
} else Case.ORIGINAL
return declarations.asSequence()
.filterIsInstance()
.map { "'${it.id}': ${it.value(case)}" }
.joinToString(",", "({", "})")
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy