pub fn ser_cluster_instance_group_specification(
object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
input: &crate::types::ClusterInstanceGroupSpecification,
) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
if let Some(var_1) = &input.instance_count {
object.key("InstanceCount").number(
#[allow(clippy::useless_conversion)]
::aws_smithy_types::Number::NegInt((*var_1).into()),
);
}
if let Some(var_2) = &input.min_instance_count {
object.key("MinInstanceCount").number(
#[allow(clippy::useless_conversion)]
::aws_smithy_types::Number::NegInt((*var_2).into()),
);
}
if let Some(var_3) = &input.instance_group_name {
object.key("InstanceGroupName").string(var_3.as_str());
}
if let Some(var_4) = &input.instance_type {
object.key("InstanceType").string(var_4.as_str());
}
if let Some(var_5) = &input.instance_requirements {
#[allow(unused_mut)]
let mut object_6 = object.key("InstanceRequirements").start_object();
crate::protocol_serde::shape_cluster_instance_requirements::ser_cluster_instance_requirements(&mut object_6, var_5)?;
object_6.finish();
}
if let Some(var_7) = &input.life_cycle_config {
#[allow(unused_mut)]
let mut object_8 = object.key("LifeCycleConfig").start_object();
crate::protocol_serde::shape_cluster_life_cycle_config::ser_cluster_life_cycle_config(&mut object_8, var_7)?;
object_8.finish();
}
if let Some(var_9) = &input.execution_role {
object.key("ExecutionRole").string(var_9.as_str());
}
if let Some(var_10) = &input.threads_per_core {
object.key("ThreadsPerCore").number(
#[allow(clippy::useless_conversion)]
::aws_smithy_types::Number::NegInt((*var_10).into()),
);
}
if let Some(var_11) = &input.instance_storage_configs {
let mut array_12 = object.key("InstanceStorageConfigs").start_array();
for item_13 in var_11 {
{
#[allow(unused_mut)]
let mut object_14 = array_12.value().start_object();
crate::protocol_serde::shape_cluster_instance_storage_config::ser_cluster_instance_storage_config(&mut object_14, item_13)?;
object_14.finish();
}
}
array_12.finish();
}
if let Some(var_15) = &input.on_start_deep_health_checks {
let mut array_16 = object.key("OnStartDeepHealthChecks").start_array();
for item_17 in var_15 {
{
array_16.value().string(item_17.as_str());
}
}
array_16.finish();
}
if let Some(var_18) = &input.training_plan_arn {
object.key("TrainingPlanArn").string(var_18.as_str());
}
if let Some(var_19) = &input.override_vpc_config {
#[allow(unused_mut)]
let mut object_20 = object.key("OverrideVpcConfig").start_object();
crate::protocol_serde::shape_vpc_config::ser_vpc_config(&mut object_20, var_19)?;
object_20.finish();
}
if let Some(var_21) = &input.scheduled_update_config {
#[allow(unused_mut)]
let mut object_22 = object.key("ScheduledUpdateConfig").start_object();
crate::protocol_serde::shape_scheduled_update_config::ser_scheduled_update_config(&mut object_22, var_21)?;
object_22.finish();
}
if let Some(var_23) = &input.image_id {
object.key("ImageId").string(var_23.as_str());
}
if let Some(var_24) = &input.kubernetes_config {
#[allow(unused_mut)]
let mut object_25 = object.key("KubernetesConfig").start_object();
crate::protocol_serde::shape_cluster_kubernetes_config::ser_cluster_kubernetes_config(&mut object_25, var_24)?;
object_25.finish();
}
if let Some(var_26) = &input.slurm_config {
#[allow(unused_mut)]
let mut object_27 = object.key("SlurmConfig").start_object();
crate::protocol_serde::shape_cluster_slurm_config::ser_cluster_slurm_config(&mut object_27, var_26)?;
object_27.finish();
}
if let Some(var_28) = &input.capacity_requirements {
#[allow(unused_mut)]
let mut object_29 = object.key("CapacityRequirements").start_object();
crate::protocol_serde::shape_cluster_capacity_requirements::ser_cluster_capacity_requirements(&mut object_29, var_28)?;
object_29.finish();
}
if let Some(var_30) = &input.network_interface {
#[allow(unused_mut)]
let mut object_31 = object.key("NetworkInterface").start_object();
crate::protocol_serde::shape_cluster_network_interface::ser_cluster_network_interface(&mut object_31, var_30)?;
object_31.finish();
}
Ok(())
}