diff --git a/utoipa-gen/CHANGELOG.md b/utoipa-gen/CHANGELOG.md index 03c2ed08..a6e757e9 100644 --- a/utoipa-gen/CHANGELOG.md +++ b/utoipa-gen/CHANGELOG.md @@ -5,6 +5,7 @@ ### Changed * Simplified `ToTokensDiagnostics` for `request_body` (https://github.com/juhaku/utoipa/pull/1235) +* Make `parse_named_attributes` a method of `MediaTypeAttr` (https://github.com/juhaku/utoipa/pull/1236) ### Fixed diff --git a/utoipa-gen/src/path/media_type.rs b/utoipa-gen/src/path/media_type.rs index fd54b58e..31cd9440 100644 --- a/utoipa-gen/src/path/media_type.rs +++ b/utoipa-gen/src/path/media_type.rs @@ -90,7 +90,7 @@ impl<'m> MediaTypeAttr<'m> { } pub fn parse_named_attributes( - media_type: &mut MediaTypeAttr, + &mut self, input: ParseStream, attribute: &Ident, ) -> syn::Result<()> { @@ -98,12 +98,12 @@ impl<'m> MediaTypeAttr<'m> { match name { "example" => { - media_type.example = Some(parse_utils::parse_next(input, || { + self.example = Some(parse_utils::parse_next(input, || { AnyValue::parse_any(input) })?) } "examples" => { - media_type.examples = parse_utils::parse_comma_separated_within_parenthesis(input)? + self.examples = parse_utils::parse_comma_separated_within_parenthesis(input)? } // // TODO implement encoding support // "encoding" => (), diff --git a/utoipa-gen/src/path/request_body.rs b/utoipa-gen/src/path/request_body.rs index d8570451..37251a58 100644 --- a/utoipa-gen/src/path/request_body.rs +++ b/utoipa-gen/src/path/request_body.rs @@ -174,14 +174,11 @@ impl Parse for RequestBodyAttr<'_> { request_body_attr.description = Some(parse::description(&group)?); } _ => { - MediaTypeAttr::parse_named_attributes( - request_body_attr - .content - .get_mut(0) - .expect("parse request body named attributes must have media type"), - &group, - &ident, - )?; + request_body_attr + .content + .get_mut(0) + .expect("parse request body named attributes must have media type") + .parse_named_attributes(&group, &ident)?; } } diff --git a/utoipa-gen/src/path/response.rs b/utoipa-gen/src/path/response.rs index 6ad97da8..177738af 100644 --- a/utoipa-gen/src/path/response.rs +++ b/utoipa-gen/src/path/response.rs @@ -323,13 +323,12 @@ impl<'r> ResponseValue<'r> { self.links = parse_utils::parse_comma_separated_within_parenthesis(input)?; } _ => { - MediaTypeAttr::parse_named_attributes( - self.content.get_mut(0).expect( + self.content + .get_mut(0) + .expect( "parse named attributes response value must have one media type by default", - ), - input, - attribute, - )?; + ) + .parse_named_attributes(input, attribute)?; } } Ok(())