Move methods to associated methods
This commit is contained in:
		
							parent
							
								
									a72d3e5fa7
								
							
						
					
					
						commit
						47b9701321
					
				| @ -16,6 +16,4 @@ serde_json = "1.0.82" | ||||
| thiserror = "1.0.31" | ||||
| 
 | ||||
| [workspace] | ||||
| members = [ | ||||
|   "qbittorrent-web-api-gen", | ||||
| ] | ||||
| members = ["qbittorrent-web-api-gen"] | ||||
|  | ||||
| @ -49,20 +49,21 @@ impl ApiParameters { | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| pub fn parse_api_method(child: &md_parser::TokenTree) -> Option<ApiMethod> { | ||||
|     util::find_content_starts_with(&child.content, "Name: ") | ||||
|         .map(|name| { | ||||
|             name.trim_start_matches("Name: ") | ||||
|                 .trim_matches('`') | ||||
|                 .to_string() | ||||
|         }) | ||||
|         .map(|name| to_api_method(child, &name)) | ||||
| } | ||||
| impl ApiMethod { | ||||
|     pub fn try_new(child: &md_parser::TokenTree) -> Option<Self> { | ||||
|         const NAME: &str = "Name: "; | ||||
| 
 | ||||
| fn to_api_method(child: &md_parser::TokenTree, name: &str) -> ApiMethod { | ||||
|     let tables = child.to_tables(); | ||||
|         child | ||||
|             .find_content_starts_with(NAME) | ||||
|             .map(|name| name.trim_start_matches(NAME).trim_matches('`').to_string()) | ||||
|             .map(|name| ApiMethod::new(child, &name)) | ||||
|     } | ||||
| 
 | ||||
|     fn new(child: &md_parser::TokenTree, name: &str) -> Self { | ||||
|         let tables = Tables::from(child); | ||||
|         let method_description = parse_method_description(&child.content); | ||||
|         let return_type = parse_return_type(&child.content); | ||||
|         // let return_type = tables.return_type().map(|r| ReturnType::new(r));
 | ||||
|         let parameters = tables.parameters().map(ApiParameters::new); | ||||
|         let method_url = get_method_url(&child.content); | ||||
| 
 | ||||
| @ -73,15 +74,22 @@ fn to_api_method(child: &md_parser::TokenTree, name: &str) -> ApiMethod { | ||||
|             return_type, | ||||
|             url: method_url, | ||||
|         } | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| impl md_parser::TokenTree { | ||||
|     fn to_tables(&self) -> Tables<'_> { | ||||
|     fn find_content_starts_with(&self, content: &str) -> Option<String> { | ||||
|         util::find_content_starts_with(&self.content, content) | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| impl<'a> From<&'a md_parser::TokenTree> for Tables<'a> { | ||||
|     fn from(token_tree: &'a md_parser::TokenTree) -> Self { | ||||
|         let mut tables = HashMap::new(); | ||||
|         let mut prev_prev: Option<&md_parser::MdContent> = None; | ||||
|         let mut prev: Option<&md_parser::MdContent> = None; | ||||
| 
 | ||||
|         for content in &self.content { | ||||
|         for content in &token_tree.content { | ||||
|             if let md_parser::MdContent::Table(table) = content { | ||||
|                 let title = match prev_prev { | ||||
|                     Some(md_parser::MdContent::Text(text)) => text.clone(), | ||||
| @ -111,7 +119,7 @@ impl<'a> Tables<'a> { | ||||
|     } | ||||
| 
 | ||||
|     // fn return_type(&self) -> Option<Vec<types::Type>> {
 | ||||
|     //     self.get_type_containing("Returns")
 | ||||
|     //     self.get_type_containing("The response is a")
 | ||||
|     // }
 | ||||
| 
 | ||||
|     fn get_type_containing(&self, name: &str) -> Option<Vec<types::Type>> { | ||||
| @ -170,7 +178,7 @@ mod tests { | ||||
| 
 | ||||
|             // when
 | ||||
|             let tree = TokenTreeFactory::create(input); | ||||
|             let api_method = parse_api_method(&tree.children[0]).unwrap(); | ||||
|             let api_method = ApiMethod::try_new(&tree.children[0]).unwrap(); | ||||
| 
 | ||||
|             // then
 | ||||
|             let api_method_as_str = format!("{api_method:#?}"); | ||||
| @ -187,7 +195,7 @@ mod tests { | ||||
|             use std::path::Path; | ||||
| 
 | ||||
|             let input = include_str!(concat!(TEST_DIR!(), "/", $test_file, ".md")); | ||||
|             let tree = TokenTreeFactory::create(input); | ||||
|             let tree = ApiMethod::try_new(input); | ||||
|             let api_method = parse_api_method(&tree.children[0]).unwrap(); | ||||
| 
 | ||||
|             let tree_as_str = format!("{tree:#?}"); | ||||
|  | ||||
| @ -4,7 +4,7 @@ mod url; | ||||
| 
 | ||||
| use crate::md_parser; | ||||
| 
 | ||||
| use self::{description::parse_group_description, method::parse_api_method, url::get_group_url}; | ||||
| use self::{description::parse_group_description, url::get_group_url}; | ||||
| pub use method::*; | ||||
| 
 | ||||
| #[derive(Debug)] | ||||
| @ -16,7 +16,7 @@ pub struct ApiGroup { | ||||
| } | ||||
| 
 | ||||
| pub fn parse_api_group(tree: &md_parser::TokenTree) -> ApiGroup { | ||||
|     let methods = tree.children.iter().flat_map(parse_api_method).collect(); | ||||
|     let methods = tree.children.iter().flat_map(ApiMethod::try_new).collect(); | ||||
| 
 | ||||
|     let group_description = parse_group_description(&tree.content); | ||||
|     let group_url = get_group_url(&tree.content); | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user