diff options
| -rw-r--r-- | mingling_cli/Cargo.lock | 10 | ||||
| -rw-r--r-- | mingling_cli/Cargo.toml | 5 | ||||
| -rw-r--r-- | mingling_cli/build.rs | 3 | ||||
| -rw-r--r-- | mingling_cli/src/dispatcher_mgr.rs (renamed from mingling_cli/src/add_dispatcher.rs) | 29 | ||||
| -rw-r--r-- | mingling_cli/src/main.rs | 14 |
5 files changed, 43 insertions, 18 deletions
diff --git a/mingling_cli/Cargo.lock b/mingling_cli/Cargo.lock index 737f437..16f7016 100644 --- a/mingling_cli/Cargo.lock +++ b/mingling_cli/Cargo.lock @@ -37,6 +37,15 @@ source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "5454cda0d57db59778608d7a47bff5b16c6705598265869fb052b657f66cf05e" [[package]] +name = "just_template" +version = "0.1.3" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "db3edb658c34b10b69c4b3b58f7ba989cd09c82c0621dee1eef51843c2327225" +dependencies = [ + "just_fmt", +] + +[[package]] name = "libc" version = "0.2.184" source = "registry+https://github.com/rust-lang/crates.io-index" @@ -74,6 +83,7 @@ name = "mingling_core" version = "0.1.4" dependencies = [ "just_fmt", + "just_template", "once_cell", "thiserror", "tokio", diff --git a/mingling_cli/Cargo.toml b/mingling_cli/Cargo.toml index 7929eb7..23a9bd7 100644 --- a/mingling_cli/Cargo.toml +++ b/mingling_cli/Cargo.toml @@ -8,6 +8,9 @@ name = "mling" path = "src/main.rs" [dependencies] -mingling = { path = "../mingling", features = ["parser"] } +mingling = { path = "../mingling", features = ["parser", "comp"] } serde = { version = "1", features = ["derive"] } tokio = { version = "1", features = ["full"] } + +[build-dependencies] +mingling = { path = "../mingling", features = ["comp"] } diff --git a/mingling_cli/build.rs b/mingling_cli/build.rs new file mode 100644 index 0000000..89e9aae --- /dev/null +++ b/mingling_cli/build.rs @@ -0,0 +1,3 @@ +fn main() { + mingling::build::build_comp_scripts("mling").unwrap(); +} diff --git a/mingling_cli/src/add_dispatcher.rs b/mingling_cli/src/dispatcher_mgr.rs index c5eaec4..483a48c 100644 --- a/mingling_cli/src/add_dispatcher.rs +++ b/mingling_cli/src/dispatcher_mgr.rs @@ -5,34 +5,43 @@ use mingling::{ parser::Picker, }; -use crate::MinglingCLI; +use crate::ThisProgram; -dispatcher!(MinglingCLI, "add.dispatcher", AddDispatcherCommand => AddDispatcherEntry); +dispatcher!("add.dispatcher", AddDispatcherCommand => AddDispatcherEntry); +dispatcher!("remove.dispatcher", RemoveDispatcherCommand => RemoveDispatcherEntry); -#[chain(MinglingCLI)] +#[chain] pub async fn parse_add_dispatcher(args: AddDispatcherEntry) -> NextProcess { - let picker: Picker<MinglingCLI> = Picker::new(args.inner); + let picker: Picker<ThisProgram> = Picker::new(args.inner); let dispatcher_name = picker.pick::<String>(()).unpack_directly().0; let input = AddDispatcherInput::new(dispatcher_name); input.into() } -pack!(MinglingCLI, AddDispatcherInput = String); +#[chain] +pub async fn parse_remove_dispatcher(args: RemoveDispatcherEntry) -> NextProcess { + let picker: Picker<ThisProgram> = Picker::new(args.inner); + let dispatcher_name = picker.pick::<String>(()).unpack_directly().0; + let input = AddDispatcherInput::new(dispatcher_name); + input.into() +} + +pack!(AddDispatcherInput = String); -#[chain(MinglingCLI)] +#[chain] pub async fn exec_add_dispatcher(_input: AddDispatcherInput) -> NextProcess { AnyOutput::new(AddDispatcherSuccess::new(())).route_chain() } -pack!(MinglingCLI, AddDispatcherSuccess = ()); -pack!(MinglingCLI, AddDispatcherFailed = String); +pack!(AddDispatcherSuccess = ()); +pack!(AddDispatcherFailed = String); -#[renderer(MinglingCLI)] +#[renderer] pub fn render_add_dispatcher_success(_prev: AddDispatcherSuccess) { r_println!("Dispatcher added successfully"); } -#[renderer(MinglingCLI)] +#[renderer] pub fn render_add_dispatcher_failed(prev: AddDispatcherFailed) { r_println!("Error: {}", prev.inner); } diff --git a/mingling_cli/src/main.rs b/mingling_cli/src/main.rs index c4dfe21..a0066f4 100644 --- a/mingling_cli/src/main.rs +++ b/mingling_cli/src/main.rs @@ -1,16 +1,16 @@ use mingling::{macros::gen_program, setup::BasicProgramSetup}; -mod add_dispatcher; -pub use crate::add_dispatcher::*; +mod dispatcher_mgr; +pub use crate::dispatcher_mgr::*; #[tokio::main] async fn main() { - let mut program = MinglingCLI::new(); + let mut program = ThisProgram::new(); program.with_setup(BasicProgramSetup); - program.with_dispatcher(AddDispatcherCommand); + program.with_dispatcher(CompletionDispatcher); + program.with_dispatchers((AddDispatcherCommand, RemoveDispatcherCommand)); - let render_result = program.exec_without_render().await.unwrap(); - println!("{}", render_result); + program.exec().await; } -gen_program!(MinglingCLI); +gen_program!(); |
