commonMain.kotlinx.serialization.encoding.AbstractEncoder.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of kotlinx-serialization-runtime Show documentation
Show all versions of kotlinx-serialization-runtime Show documentation
Kotlin multiplatform serialization runtime library
The newest version!
/*
* Copyright 2017-2020 JetBrains s.r.o. Use of this source code is governed by the Apache 2.0 license.
*/
package kotlinx.serialization.encoding
import kotlinx.serialization.*
import kotlinx.serialization.descriptors.*
import kotlinx.serialization.modules.*
/**
* A skeleton implementation of both [Encoder] and [CompositeEncoder] that can be used
* for simple formats and for testability purpose.
* Most of the `encode*` methods have default implementation that delegates `encodeValue(value: Any)`.
* See [Encoder] documentation for information about each particular `encode*` method.
*/
public abstract class AbstractEncoder : Encoder, CompositeEncoder {
override val serializersModule: SerializersModule
get() = EmptySerializersModule
// do not update signature here because new signature is called by the plugin;
// and clients that have old signature would not be called.
@Suppress("OverridingDeprecatedMember")
@Deprecated(
"Parameter typeSerializers is deprecated for removal. Please migrate to beginStructure method with one argument.",
ReplaceWith("beginStructure(descriptor)"),
DeprecationLevel.ERROR
)
override fun beginStructure(
descriptor: SerialDescriptor,
vararg typeSerializers: KSerializer<*>
): CompositeEncoder = this
/**
* Invoked before writing an element that is part of the structure to determine whether it should be encoded.
* Element information can be obtained from the [descriptor] by the given [index].
*
* @return `true` if the value should be encoded, false otherwise
*/
public open fun encodeElement(descriptor: SerialDescriptor, index: Int): Boolean = true
/**
* Invoked to encode a value when specialized `encode*` method was not overridden.
*/
public open fun encodeValue(value: Any): Unit =
throw SerializationException("Non-serializable ${value::class} is not supported by ${this::class} encoder")
override fun encodeNull() {
throw SerializationException("'null' is not supported by default")
}
override fun encodeBoolean(value: Boolean): Unit = encodeValue(value)
override fun encodeByte(value: Byte): Unit = encodeValue(value)
override fun encodeShort(value: Short): Unit = encodeValue(value)
override fun encodeInt(value: Int): Unit = encodeValue(value)
override fun encodeLong(value: Long): Unit = encodeValue(value)
override fun encodeFloat(value: Float): Unit = encodeValue(value)
override fun encodeDouble(value: Double): Unit = encodeValue(value)
override fun encodeChar(value: Char): Unit = encodeValue(value)
override fun encodeString(value: String): Unit = encodeValue(value)
override fun encodeEnum(enumDescriptor: SerialDescriptor, index: Int): Unit = encodeValue(index)
// Delegating implementation of CompositeEncoder
final override fun encodeBooleanElement(descriptor: SerialDescriptor, index: Int, value: Boolean) { if (encodeElement(descriptor, index)) encodeBoolean(value) }
final override fun encodeByteElement(descriptor: SerialDescriptor, index: Int, value: Byte) { if (encodeElement(descriptor, index)) encodeByte(value) }
final override fun encodeShortElement(descriptor: SerialDescriptor, index: Int, value: Short) { if (encodeElement(descriptor, index)) encodeShort(value) }
final override fun encodeIntElement(descriptor: SerialDescriptor, index: Int, value: Int) { if (encodeElement(descriptor, index)) encodeInt(value) }
final override fun encodeLongElement(descriptor: SerialDescriptor, index: Int, value: Long) { if (encodeElement(descriptor, index)) encodeLong(value) }
final override fun encodeFloatElement(descriptor: SerialDescriptor, index: Int, value: Float) { if (encodeElement(descriptor, index)) encodeFloat(value) }
final override fun encodeDoubleElement(descriptor: SerialDescriptor, index: Int, value: Double) { if (encodeElement(descriptor, index)) encodeDouble(value) }
final override fun encodeCharElement(descriptor: SerialDescriptor, index: Int, value: Char) { if (encodeElement(descriptor, index)) encodeChar(value) }
final override fun encodeStringElement(descriptor: SerialDescriptor, index: Int, value: String) { if (encodeElement(descriptor, index)) encodeString(value) }
final override fun encodeSerializableElement(
descriptor: SerialDescriptor,
index: Int,
serializer: SerializationStrategy,
value: T
) {
if (encodeElement(descriptor, index))
encodeSerializableValue(serializer, value)
}
final override fun encodeNullableSerializableElement(
descriptor: SerialDescriptor,
index: Int,
serializer: SerializationStrategy,
value: T?
) {
if (encodeElement(descriptor, index))
encodeNullableSerializableValue(serializer, value)
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy