#[allow(clippy::needless_question_mark)]
pub fn de_account_limit(
decoder: &mut ::aws_smithy_xml::decode::ScopedDecoder,
) -> ::std::result::Result<crate::types::AccountLimit, ::aws_smithy_xml::decode::XmlDecodeError> {
#[allow(unused_mut)]
let mut builder = crate::types::AccountLimit::builder();
while let Some(mut tag) = decoder.next_tag() {
match tag.start_el() {
s if s.matches("Type") => {
let var_1 =
Some(
Result::<crate::types::AccountLimitType, ::aws_smithy_xml::decode::XmlDecodeError>::Ok(
crate::types::AccountLimitType::from(
::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
)
)
?
)
;
builder = builder.set_type(var_1);
}
,
s if s.matches("Value") => {
let var_2 =
Some(
{
<i64 as ::aws_smithy_types::primitive::Parse>::parse_smithy_primitive(
::aws_smithy_xml::decode::try_data(&mut tag)?.as_ref()
)
.map_err(|_|::aws_smithy_xml::decode::XmlDecodeError::custom("expected (long: `com.amazonaws.route53#LimitValue`)"))
}
?
)
;
builder = builder.set_value(var_2);
}
,
_ => {}
}
}
Ok(crate::serde_util::account_limit_correct_errors(builder)
.build()
.map_err(|_| ::aws_smithy_xml::decode::XmlDecodeError::custom("missing field"))?)
}