From 17db6e4dad312d58d4f118ea7542b1ed835d7675 Mon Sep 17 00:00:00 2001 From: 魏曹先生 <1992414357@qq.com> Date: Thu, 12 Mar 2026 20:36:09 +0800 Subject: Add helpdoc list command --- src/cmds/arg/empty.rs | 4 ++++ src/cmds/arg/helpdoc.rs | 2 +- src/cmds/cmd/helpdoc.rs | 6 +++--- src/cmds/cmd/helpdoc_list.rs | 48 +++++++++++++++++++++++++++++++++++++++++++ src/cmds/out/helpdocs.rs | 6 ++++++ src/cmds/renderer/helpdocs.rs | 14 +++++++++++++ 6 files changed, 76 insertions(+), 4 deletions(-) create mode 100644 src/cmds/arg/empty.rs create mode 100644 src/cmds/cmd/helpdoc_list.rs create mode 100644 src/cmds/out/helpdocs.rs create mode 100644 src/cmds/renderer/helpdocs.rs (limited to 'src/cmds') diff --git a/src/cmds/arg/empty.rs b/src/cmds/arg/empty.rs new file mode 100644 index 0000000..24d7895 --- /dev/null +++ b/src/cmds/arg/empty.rs @@ -0,0 +1,4 @@ +use clap::Parser; + +#[derive(Parser, Debug)] +pub struct JVEmptyArgument {} diff --git a/src/cmds/arg/helpdoc.rs b/src/cmds/arg/helpdoc.rs index 3a34123..8950628 100644 --- a/src/cmds/arg/helpdoc.rs +++ b/src/cmds/arg/helpdoc.rs @@ -2,5 +2,5 @@ use clap::Parser; #[derive(Parser, Debug)] pub struct JVHelpdocArgument { - pub doc_name: String, + pub doc_name: Option, } diff --git a/src/cmds/cmd/helpdoc.rs b/src/cmds/cmd/helpdoc.rs index 8b692ee..bebd08c 100644 --- a/src/cmds/cmd/helpdoc.rs +++ b/src/cmds/cmd/helpdoc.rs @@ -9,7 +9,7 @@ use crate::{ cmd_system::JVCommandContext, errors::{CmdExecuteError, CmdPrepareError}, }, - helpdoc::helpdoc_viewer, + helpdoc::{DEFAULT_HELPDOC, helpdoc_viewer}, }, }; use cmd_system_macros::exec; @@ -22,13 +22,13 @@ type In = JVHelpdocInput; type Collect = JVEmptyCollect; async fn help_str() -> String { - helpdoc_viewer::display("Welcome_To_JVCS").await; + helpdoc_viewer::display(DEFAULT_HELPDOC).await; String::new() } async fn prepare(args: &Arg, ctx: &JVCommandContext) -> Result { Ok(JVHelpdocInput { - name: args.doc_name.clone(), + name: args.doc_name.clone().unwrap_or(DEFAULT_HELPDOC.to_string()), lang: ctx.lang.clone(), }) } diff --git a/src/cmds/cmd/helpdoc_list.rs b/src/cmds/cmd/helpdoc_list.rs new file mode 100644 index 0000000..b4b05cf --- /dev/null +++ b/src/cmds/cmd/helpdoc_list.rs @@ -0,0 +1,48 @@ +use crate::{ + cmd_output, + cmds::{ + arg::empty::JVEmptyArgument, collect::empty::JVEmptyCollect, r#in::empty::JVEmptyInput, + out::helpdocs::JVHelpdocsOutput, + }, + systems::{ + cmd::{ + cmd_system::JVCommandContext, + errors::{CmdExecuteError, CmdPrepareError}, + }, + helpdoc::{DEFAULT_HELPDOC, get_helpdoc_list, helpdoc_viewer}, + }, +}; +use cmd_system_macros::exec; +use std::any::TypeId; + +pub struct JVHelpdocListCommand; +type Cmd = JVHelpdocListCommand; +type Arg = JVEmptyArgument; +type In = JVEmptyInput; +type Collect = JVEmptyCollect; + +async fn help_str() -> String { + helpdoc_viewer::display(DEFAULT_HELPDOC).await; + String::new() +} + +async fn prepare(_args: &Arg, _ctx: &JVCommandContext) -> Result { + Ok(JVEmptyInput) +} + +async fn collect(_args: &Arg, _ctx: &JVCommandContext) -> Result { + Ok(JVEmptyCollect) +} + +#[exec] +async fn exec( + _input: In, + _collect: Collect, +) -> Result<(Box, TypeId), CmdExecuteError> { + let output = JVHelpdocsOutput { + names: get_helpdoc_list().into_iter().map(String::from).collect(), + }; + cmd_output!(JVHelpdocsOutput => output) +} + +crate::command_template!(); diff --git a/src/cmds/out/helpdocs.rs b/src/cmds/out/helpdocs.rs new file mode 100644 index 0000000..72142db --- /dev/null +++ b/src/cmds/out/helpdocs.rs @@ -0,0 +1,6 @@ +use serde::Serialize; + +#[derive(Serialize)] +pub struct JVHelpdocsOutput { + pub names: Vec, +} diff --git a/src/cmds/renderer/helpdocs.rs b/src/cmds/renderer/helpdocs.rs new file mode 100644 index 0000000..8fc34e0 --- /dev/null +++ b/src/cmds/renderer/helpdocs.rs @@ -0,0 +1,14 @@ +use render_system_macros::result_renderer; + +use crate::{ + cmds::out::helpdocs::JVHelpdocsOutput, + r_println, + systems::{cmd::errors::CmdRenderError, render::renderer::JVRenderResult}, +}; + +#[result_renderer(JVHelpdocsRenderer)] +pub async fn render(data: &JVHelpdocsOutput) -> Result { + let mut r = JVRenderResult::default(); + data.names.iter().for_each(|d| r_println!(r, "{}", d)); + Ok(r) +} -- cgit