From f430e82b7a6cf9570a874ea2a136a99a96518796 Mon Sep 17 00:00:00 2001 From: Joel Wachsler Date: Tue, 19 Jul 2022 21:04:18 +0000 Subject: [PATCH] Move more functionality --- .../src/parser/group/method/return_type.rs | 62 ++++++++++++------- 1 file changed, 39 insertions(+), 23 deletions(-) diff --git a/qbittorrent-web-api-gen/src/parser/group/method/return_type.rs b/qbittorrent-web-api-gen/src/parser/group/method/return_type.rs index 3691c1f..0dccc17 100644 --- a/qbittorrent-web-api-gen/src/parser/group/method/return_type.rs +++ b/qbittorrent-web-api-gen/src/parser/group/method/return_type.rs @@ -33,17 +33,7 @@ impl md_parser::TokenTree { let parameters = table .rows .iter() - .map(|parameter| ReturnTypeParameter { - name: parameter.columns[0].clone(), - description: parameter.columns[2].clone(), - return_type: types::Type::from( - ¶meter.columns[1], - ¶meter.columns[0], - Some(parameter.columns[2].clone()), - &types, - ) - .unwrap_or_else(|| panic!("Failed to parse type {}", ¶meter.columns[1])), - }) + .map(|parameter| parameter.to_return_type_parameter(&types)) .collect(); Some(ReturnType { @@ -74,14 +64,12 @@ impl md_parser::TokenTree { // is empty content_it.next(); if let Some(md_parser::MdContent::Table(table)) = content_it.next() { - let enum_types = to_type_descriptions(table); - let name = content .trim_start_matches(POSSIBLE_VALUES_OF) .replace('`', "") .replace(':', ""); - output.insert(name, types::TypeDescription { values: enum_types }); + output.insert(name, table.to_type_description()); } } } @@ -91,13 +79,41 @@ impl md_parser::TokenTree { } } -fn to_type_descriptions(table: &md_parser::Table) -> Vec { - table - .rows - .iter() - .map(|row| types::TypeDescriptions { - value: row.columns[0].to_string(), - description: row.columns[1].to_string(), - }) - .collect() +impl md_parser::Table { + pub fn to_type_description(&self) -> types::TypeDescription { + types::TypeDescription { + values: self.to_type_descriptions(), + } + } + + pub fn to_type_descriptions(&self) -> Vec { + self.rows + .iter() + .map(|row| types::TypeDescriptions { + value: row.columns[0].to_string(), + description: row.columns[1].to_string(), + }) + .collect() + } +} + +impl md_parser::TableRow { + fn to_return_type_parameter( + &self, + types: &HashMap, + ) -> ReturnTypeParameter { + let columns = &self.columns; + + ReturnTypeParameter { + name: columns[0].clone(), + description: columns[2].clone(), + return_type: types::Type::from( + &columns[1], + &columns[0], + Some(columns[2].clone()), + types, + ) + .unwrap_or_else(|| panic!("Failed to parse type {}", &columns[1])), + } + } }