diff options
author | Cyborus <cyborus@cyborus.xyz> | 2024-02-10 01:22:26 +0100 |
---|---|---|
committer | Cyborus <cyborus@cyborus.xyz> | 2024-02-10 01:22:26 +0100 |
commit | 8cf3213267de01d67b716267f6ca7c06535455ea (patch) | |
tree | 273051ab5880dabcb33776aa715a2558422644f4 /generator | |
parent | include enum types in fields (diff) | |
download | forgejo-api-8cf3213267de01d67b716267f6ca7c06535455ea.tar.xz forgejo-api-8cf3213267de01d67b716267f6ca7c06535455ea.zip |
deref more params
Diffstat (limited to 'generator')
-rw-r--r-- | generator/src/methods.rs | 5 | ||||
-rw-r--r-- | generator/src/structs.rs | 25 |
2 files changed, 12 insertions, 18 deletions
diff --git a/generator/src/methods.rs b/generator/src/methods.rs index 173ede5..28f9c73 100644 --- a/generator/src/methods.rs +++ b/generator/src/methods.rs @@ -345,10 +345,7 @@ fn create_method_request( let mut body_method = String::new(); if let Some(params) = &op.parameters { for param in params { - let param = match ¶m { - MaybeRef::Value { value } => value, - MaybeRef::Ref { _ref } => eyre::bail!("todo: add deref parameters"), - }; + let param = param.deref(spec)?; let name = crate::sanitize_ident(¶m.name); match ¶m._in { ParameterIn::Path { param: _ } => (/* do nothing */), diff --git a/generator/src/structs.rs b/generator/src/structs.rs index aa6bf0c..ef61a8f 100644 --- a/generator/src/structs.rs +++ b/generator/src/structs.rs @@ -23,7 +23,7 @@ pub fn create_structs(spec: &OpenApiV2) -> eyre::Result<String> { } } for (_, item) in &spec.paths { - let strukt = create_query_structs_for_path(item)?; + let strukt = create_query_structs_for_path(spec, item)?; s.push_str(&strukt); } s.push_str("\n}"); @@ -223,28 +223,28 @@ fn create_struct_docs_str(description: Option<&str>) -> eyre::Result<String> { Ok(doc) } -pub fn create_query_structs_for_path(item: &PathItem) -> eyre::Result<String> { +pub fn create_query_structs_for_path(spec: &OpenApiV2, item: &PathItem) -> eyre::Result<String> { let mut s = String::new(); if let Some(op) = &item.get { - s.push_str(&create_query_struct(op).wrap_err("GET")?); + s.push_str(&create_query_struct(spec, op).wrap_err("GET")?); } if let Some(op) = &item.put { - s.push_str(&create_query_struct(op).wrap_err("PUT")?); + s.push_str(&create_query_struct(spec, op).wrap_err("PUT")?); } if let Some(op) = &item.post { - s.push_str(&create_query_struct(op).wrap_err("POST")?); + s.push_str(&create_query_struct(spec, op).wrap_err("POST")?); } if let Some(op) = &item.delete { - s.push_str(&create_query_struct(op).wrap_err("DELETE")?); + s.push_str(&create_query_struct(spec, op).wrap_err("DELETE")?); } if let Some(op) = &item.options { - s.push_str(&create_query_struct(op).wrap_err("OPTIONS")?); + s.push_str(&create_query_struct(spec, op).wrap_err("OPTIONS")?); } if let Some(op) = &item.head { - s.push_str(&create_query_struct(op).wrap_err("HEAD")?); + s.push_str(&create_query_struct(spec, op).wrap_err("HEAD")?); } if let Some(op) = &item.patch { - s.push_str(&create_query_struct(op).wrap_err("PATCH")?); + s.push_str(&create_query_struct(spec, op).wrap_err("PATCH")?); } Ok(s) } @@ -260,7 +260,7 @@ pub fn query_struct_name(op: &Operation) -> eyre::Result<String> { Ok(ty) } -fn create_query_struct(op: &Operation) -> eyre::Result<String> { +fn create_query_struct(spec: &OpenApiV2, op: &Operation) -> eyre::Result<String> { let params = match &op.parameters { Some(params) => params, None => return Ok(String::new()), @@ -271,10 +271,7 @@ fn create_query_struct(op: &Operation) -> eyre::Result<String> { let mut fields = String::new(); let mut imp = String::new(); for param in params { - let param = match ¶m { - MaybeRef::Value { value } => value, - MaybeRef::Ref { _ref } => eyre::bail!("todo: add deref parameters"), - }; + let param = param.deref(spec)?; if let ParameterIn::Query { param: query_param } = ¶m._in { let field_name = crate::sanitize_ident(¶m.name); let ty = match &query_param { |