All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.lightningkite.lightningdb.SortPartSerializer.kt Maven / Gradle / Ivy

@file:OptIn(InternalSerializationApi::class, ExperimentalSerializationApi::class)

package com.lightningkite.lightningdb

import kotlinx.serialization.ExperimentalSerializationApi
import kotlinx.serialization.InternalSerializationApi
import kotlinx.serialization.KSerializer
import kotlinx.serialization.descriptors.PrimitiveKind
import kotlinx.serialization.descriptors.PrimitiveSerialDescriptor
import kotlinx.serialization.descriptors.SerialDescriptor
import kotlinx.serialization.descriptors.SerialKind
import kotlinx.serialization.encoding.Decoder
import kotlinx.serialization.encoding.Encoder

class SortPartSerializer(val inner: KSerializer): KSerializer> {
    @OptIn(ExperimentalSerializationApi::class)
    override val descriptor: SerialDescriptor = object: SerialDescriptor {
        override val kind: SerialKind = PrimitiveKind.STRING
        override val serialName: String = "com.lightningkite.lightningdb.SortPart"
        override val elementsCount: Int get() = 0
        override fun getElementName(index: Int): String = error()
        override fun getElementIndex(name: String): Int = error()
        override fun isElementOptional(index: Int): Boolean = error()
        override fun getElementDescriptor(index: Int): SerialDescriptor = error()
        override fun getElementAnnotations(index: Int): List = error()
        override fun toString(): String = "PrimitiveDescriptor($serialName)"
        private fun error(): Nothing = throw IllegalStateException("Primitive descriptor does not have elements")
        override val annotations: List = SortPart::class.annotations
    }

    val fields = inner.attemptGrabFields()
    val sub = DataClassPathSerializer(inner)

    override fun deserialize(decoder: Decoder): SortPart {
        val value = decoder.decodeString()
        val descending = value.startsWith('-')
        val nameWithoutCase = value.removePrefix("-")
        val ignoreCase = nameWithoutCase.startsWith('~')
        val name = nameWithoutCase.removePrefix("~")
        return SortPart(sub.fromString(name), !descending, ignoreCase)
    }

    override fun serialize(encoder: Encoder, value: SortPart) {
        encoder.encodeString(buildString {
            if(!value.ascending) append('-')
            if(value.ignoreCase) append('~')
            append(value.field.toString())
        })
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy