123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136 |
- use super::event_template::*;
- use crate::util::*;
- use flowy_ast::{event_ast::*, *};
- use syn::Item;
- use walkdir::WalkDir;
- pub struct DartEventCodeGen {
- pub rust_sources: Vec<String>,
- pub output_dir: String,
- }
- impl DartEventCodeGen {
- pub fn gen(&self) {
- let event_crates = parse_dart_event_files(self.rust_sources.clone());
- let event_ast = event_crates
- .iter()
- .map(parse_event_crate)
- .flatten()
- .collect::<Vec<_>>();
- let event_render_ctx = ast_to_event_render_ctx(event_ast.as_ref());
- let mut render_result = String::new();
- for (index, render_ctx) in event_render_ctx.into_iter().enumerate() {
- let mut event_template = EventTemplate::new();
- if let Some(content) = event_template.render(render_ctx, index) {
- render_result.push_str(content.as_ref())
- }
- }
- save_content_to_file_with_diff_prompt(
- render_result.as_ref(),
- self.output_dir.as_str(),
- true,
- );
- }
- }
- pub struct DartEventCrate {
- crate_path: String,
- #[allow(dead_code)]
- crate_name: String,
- event_files: Vec<String>,
- }
- impl DartEventCrate {
- pub fn from_config(config: &CrateConfig) -> Self {
- DartEventCrate {
- crate_path: config.crate_path.clone(),
- crate_name: config.folder_name.clone(),
- event_files: config.flowy_config.event_files.clone(),
- }
- }
- }
- pub fn parse_dart_event_files(roots: Vec<String>) -> Vec<DartEventCrate> {
- let mut dart_event_crates: Vec<DartEventCrate> = vec![];
- roots.iter().for_each(|root| {
- let crates = WalkDir::new(root)
- .into_iter()
- .filter_entry(|e| !is_hidden(e))
- .filter_map(|e| e.ok())
- .filter(is_crate_dir)
- .flat_map(|e| parse_crate_config_from(&e))
- .map(|crate_config| DartEventCrate::from_config(&crate_config))
- .collect::<Vec<DartEventCrate>>();
- dart_event_crates.extend(crates);
- });
- dart_event_crates
- }
- pub fn parse_event_crate(event_crate: &DartEventCrate) -> Vec<EventASTContext> {
- event_crate
- .event_files
- .iter()
- .map(|event_file| {
- let file_path = format!("{}/{}", event_crate.crate_path, event_file);
- let file_content = read_file(file_path.as_ref()).unwrap();
- let ast = syn::parse_file(file_content.as_ref()).expect("Unable to parse file");
- ast.items
- .iter()
- .map(|item| match item {
- Item::Enum(item_enum) => {
- let ctxt = Ctxt::new();
- let attrs = flowy_ast::enum_from_ast(
- &ctxt,
- &item_enum.ident,
- &item_enum.variants,
- &item_enum.attrs,
- );
- ctxt.check().unwrap();
- attrs
- .iter()
- .filter(|attr| !attr.attrs.event_attrs.ignore)
- .enumerate()
- .map(|(_index, attr)| EventASTContext::from(&attr.attrs))
- .collect::<Vec<_>>()
- }
- _ => vec![],
- })
- .flatten()
- .collect::<Vec<_>>()
- })
- .flatten()
- .collect::<Vec<EventASTContext>>()
- }
- pub fn ast_to_event_render_ctx(ast: &[EventASTContext]) -> Vec<EventRenderContext> {
- ast.iter()
- .map(|event_ast| {
- let input_deserializer = event_ast
- .event_input
- .as_ref()
- .map(|event_input| event_input.get_ident().unwrap().to_string());
- let output_deserializer = event_ast
- .event_output
- .as_ref()
- .map(|event_output| event_output.get_ident().unwrap().to_string());
- // eprintln!(
- // "😁 {:?} / {:?}",
- // event_ast.event_input, event_ast.event_output
- // );
- EventRenderContext {
- input_deserializer,
- output_deserializer,
- error_deserializer: event_ast.event_error.clone(),
- event: event_ast.event.to_string(),
- event_ty: event_ast.event_ty.to_string(),
- }
- })
- .collect::<Vec<EventRenderContext>>()
- }
|