aws_sdk_batch/protocol_serde/
shape_fairshare_policy.rs1pub fn ser_fairshare_policy(
3 object: &mut ::aws_smithy_json::serialize::JsonObjectWriter,
4 input: &crate::types::FairsharePolicy,
5) -> ::std::result::Result<(), ::aws_smithy_types::error::operation::SerializationError> {
6 if let Some(var_1) = &input.share_decay_seconds {
7 object.key("shareDecaySeconds").number(
8 #[allow(clippy::useless_conversion)]
9 ::aws_smithy_types::Number::NegInt((*var_1).into()),
10 );
11 }
12 if let Some(var_2) = &input.compute_reservation {
13 object.key("computeReservation").number(
14 #[allow(clippy::useless_conversion)]
15 ::aws_smithy_types::Number::NegInt((*var_2).into()),
16 );
17 }
18 if let Some(var_3) = &input.share_distribution {
19 let mut array_4 = object.key("shareDistribution").start_array();
20 for item_5 in var_3 {
21 {
22 #[allow(unused_mut)]
23 let mut object_6 = array_4.value().start_object();
24 crate::protocol_serde::shape_share_attributes::ser_share_attributes(&mut object_6, item_5)?;
25 object_6.finish();
26 }
27 }
28 array_4.finish();
29 }
30 Ok(())
31}
32
33pub(crate) fn de_fairshare_policy<'a, I>(
34 tokens: &mut ::std::iter::Peekable<I>,
35) -> ::std::result::Result<Option<crate::types::FairsharePolicy>, ::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::FairsharePolicyBuilder::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 "shareDecaySeconds" => {
49 builder = builder.set_share_decay_seconds(
50 ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
51 .map(i32::try_from)
52 .transpose()?,
53 );
54 }
55 "computeReservation" => {
56 builder = builder.set_compute_reservation(
57 ::aws_smithy_json::deserialize::token::expect_number_or_null(tokens.next())?
58 .map(i32::try_from)
59 .transpose()?,
60 );
61 }
62 "shareDistribution" => {
63 builder =
64 builder.set_share_distribution(crate::protocol_serde::shape_share_attributes_list::de_share_attributes_list(tokens)?);
65 }
66 _ => ::aws_smithy_json::deserialize::token::skip_value(tokens)?,
67 },
68 other => {
69 return Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(format!(
70 "expected object key or end object, found: {other:?}"
71 )))
72 }
73 }
74 }
75 Ok(Some(builder.build()))
76 }
77 _ => Err(::aws_smithy_json::deserialize::error::DeserializeError::custom(
78 "expected start object or null",
79 )),
80 }
81}