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

commonMain.aws.sdk.kotlin.services.athena.serde.EngineConfigurationDocumentSerializer.kt Maven / Gradle / Ivy

The newest version!
// Code generated by smithy-kotlin-codegen. DO NOT EDIT!

package aws.sdk.kotlin.services.athena.serde

import aws.sdk.kotlin.services.athena.model.EngineConfiguration
import aws.smithy.kotlin.runtime.serde.SdkFieldDescriptor
import aws.smithy.kotlin.runtime.serde.SdkObjectDescriptor
import aws.smithy.kotlin.runtime.serde.SerialKind
import aws.smithy.kotlin.runtime.serde.Serializer
import aws.smithy.kotlin.runtime.serde.asSdkSerializable
import aws.smithy.kotlin.runtime.serde.deserializeList
import aws.smithy.kotlin.runtime.serde.deserializeMap
import aws.smithy.kotlin.runtime.serde.deserializeStruct
import aws.smithy.kotlin.runtime.serde.field
import aws.smithy.kotlin.runtime.serde.json.JsonDeserializer
import aws.smithy.kotlin.runtime.serde.json.JsonSerialName
import aws.smithy.kotlin.runtime.serde.serializeList
import aws.smithy.kotlin.runtime.serde.serializeMap
import aws.smithy.kotlin.runtime.serde.serializeStruct

internal fun serializeEngineConfigurationDocument(serializer: Serializer, input: EngineConfiguration) {
    val ADDITIONALCONFIGS_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Map, JsonSerialName("AdditionalConfigs"))
    val COORDINATORDPUSIZE_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Integer, JsonSerialName("CoordinatorDpuSize"))
    val DEFAULTEXECUTORDPUSIZE_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Integer, JsonSerialName("DefaultExecutorDpuSize"))
    val MAXCONCURRENTDPUS_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Integer, JsonSerialName("MaxConcurrentDpus"))
    val SPARKPROPERTIES_DESCRIPTOR = SdkFieldDescriptor(SerialKind.Map, JsonSerialName("SparkProperties"))
    val OBJ_DESCRIPTOR = SdkObjectDescriptor.build {
        field(ADDITIONALCONFIGS_DESCRIPTOR)
        field(COORDINATORDPUSIZE_DESCRIPTOR)
        field(DEFAULTEXECUTORDPUSIZE_DESCRIPTOR)
        field(MAXCONCURRENTDPUS_DESCRIPTOR)
        field(SPARKPROPERTIES_DESCRIPTOR)
    }

    serializer.serializeStruct(OBJ_DESCRIPTOR) {
        input.coordinatorDpuSize?.let { field(COORDINATORDPUSIZE_DESCRIPTOR, it) }
        field(MAXCONCURRENTDPUS_DESCRIPTOR, input.maxConcurrentDpus)
        input.defaultExecutorDpuSize?.let { field(DEFAULTEXECUTORDPUSIZE_DESCRIPTOR, it) }
        if (input.additionalConfigs != null) {
            mapField(ADDITIONALCONFIGS_DESCRIPTOR) {
                input.additionalConfigs.forEach { (key, value) ->
                    entry(key, value)
                }
            }
        }
        if (input.sparkProperties != null) {
            mapField(SPARKPROPERTIES_DESCRIPTOR) {
                input.sparkProperties.forEach { (key, value) ->
                    entry(key, value)
                }
            }
        }
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy