aws_sdk_sagemaker/protocol_serde/
shape_rolling_update_policy.rs1pub fn ser_rolling_update_policy(
3 object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
4 input: &crate::types::RollingUpdatePolicy,
5) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
6 if let Some(var_1) = &input.maximum_batch_size {
7 #[allow(unused_mut)]
8 let mut object_2 = object.key("MaximumBatchSize").start_object();
9 crate::protocol_serde::shape_capacity_size::ser_capacity_size(&mut object_2, var_1)?;
10 object_2.finish();
11 }
12 if let Some(var_3) = &input.wait_interval_in_seconds {
13 object.key("WaitIntervalInSeconds").number(
14 #[allow(clippy::useless_conversion)]
15 ::aws_smithy_types::Number::NegInt((*var_3).into()),
16 );
17 }
18 if let Some(var_4) = &input.maximum_execution_timeout_in_seconds {
19 object.key("MaximumExecutionTimeoutInSeconds").number(
20 #[allow(clippy::useless_conversion)]
21 ::aws_smithy_types::Number::NegInt((*var_4).into()),
22 );
23 }
24 if let Some(var_5) = &input.rollback_maximum_batch_size {
25 #[allow(unused_mut)]
26 let mut object_6 = object.key("RollbackMaximumBatchSize").start_object();
27 crate::protocol_serde::shape_capacity_size::ser_capacity_size(&mut object_6, var_5)?;
28 object_6.finish();
29 }
30 Ok(())
31}
32
33pub(crate) fn de_rolling_update_policy<'a, I>(
34 tokens: &mut ::std::iter::Peekable<I>,
35) -> ::std::result::Result<Option<crate::types::RollingUpdatePolicy>, ::aws_smithy_json::deserialize::error::DeserializeError>
36where
37 I: Iterator<Item = Result<::aws_smithy_json::deserialize::Token<'a>, ::aws_smithy_json::deserialize::error::DeserializeError>>,
38{
39 match tokens.next().transpose()? {
40 Some(::aws_smithy_json::deserialize::Token::ValueNull { .. }) => Ok(None),
41 Some(::aws_smithy_json::deserialize::Token::StartObject { .. }) => {
42 #[allow(unused_mut)]
43 let mut builder = crate::types::builders::RollingUpdatePolicyBuilder::default();
44 loop {
45 match tokens.next().transpose()? {
46 Some(::aws_smithy_json::deserialize::Token::EndObject { .. }) => break,
47 Some(::aws_smithy_json::deserialize::Token::ObjectKey { key, .. }) => match key.to_unescaped()?.as_ref() {
48 "MaximumBatchSize" => {
49 builder = builder.set_maximum_batch_size(crate::protocol_serde::shape_capacity_size::de_capacity_size(tokens)?);
50 }
51 "WaitIntervalInSeconds" => {
52 builder = builder.set_wait_interval_in_seconds(
53 ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
54 .map(i32::try_from)
55 .transpose()?,
56 );
57 }
58 "MaximumExecutionTimeoutInSeconds" => {
59 builder = builder.set_maximum_execution_timeout_in_seconds(
60 ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
61 .map(i32::try_from)
62 .transpose()?,
63 );
64 }
65 "RollbackMaximumBatchSize" => {
66 builder = builder.set_rollback_maximum_batch_size(crate::protocol_serde::shape_capacity_size::de_capacity_size(tokens)?);
67 }
68 _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
69 },
70 other => {
71 return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
72 "expected object key or end object, found: {:?}",
73 other
74 )))
75 }
76 }
77 }
78 Ok(Some(crate::serde_util::rolling_update_policy_correct_errors(builder).build()))
79 }
80 _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
81 "expected start object or null",
82 )),
83 }
84}