aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorWeicao-CatilGrass <1992414357@qq.com>2026-04-14 03:03:21 +0800
committerWeicao-CatilGrass <1992414357@qq.com>2026-04-14 03:03:21 +0800
commit33469c75614c444f512fd51dbc78a31a9a4bec82 (patch)
treed8ba8fbc76a8cbb2bdee60ae4569b85dbd1e3402
parent56c24db7bcd92e2eb9a779bd141fcc73a7c433c0 (diff)
Rename add_dispatcher module to dispatcher_mgr and add remove command
-rw-r--r--mingling_cli/Cargo.lock10
-rw-r--r--mingling_cli/Cargo.toml5
-rw-r--r--mingling_cli/build.rs3
-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.rs14
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!();