From 3403f44cf6861f3b5c7c4d815a421dc0502d7fab Mon Sep 17 00:00:00 2001 From: Ed Page Date: Thu, 9 Nov 2023 14:50:22 -0600 Subject: [PATCH] fix(help): Recurse help flattening --- clap_builder/src/output/help_template.rs | 16 ++++++---- tests/builder/help.rs | 38 ++++++++++++++++++++++++ 2 files changed, 48 insertions(+), 6 deletions(-) diff --git a/clap_builder/src/output/help_template.rs b/clap_builder/src/output/help_template.rs index f2faea07b47a..92a039dfe1c2 100644 --- a/clap_builder/src/output/help_template.rs +++ b/clap_builder/src/output/help_template.rs @@ -479,7 +479,7 @@ impl<'cmd, 'writer> HelpTemplate<'cmd, 'writer> { if flatten { let mut cmd = self.cmd.clone(); cmd.build(); - self.write_flat_subcommands(&cmd, first); + self.write_flat_subcommands(&cmd, &mut first); } } @@ -881,10 +881,11 @@ impl<'cmd, 'writer> HelpTemplate<'cmd, 'writer> { /// Subcommand handling impl<'cmd, 'writer> HelpTemplate<'cmd, 'writer> { /// Writes help for subcommands of a Parser Object to the wrapped stream. - fn write_flat_subcommands(&mut self, cmd: &Command, mut first: bool) { + fn write_flat_subcommands(&mut self, cmd: &Command, first: &mut bool) { debug!( - "HelpTemplate::write_flat_subcommands, cmd={}, first={first}", - cmd.get_name() + "HelpTemplate::write_flat_subcommands, cmd={}, first={}", + cmd.get_name(), + *first ); use std::fmt::Write as _; let header = &self.styles.get_header(); @@ -902,10 +903,10 @@ impl<'cmd, 'writer> HelpTemplate<'cmd, 'writer> { } ord_v.sort_by(|a, b| (a.0, &a.1).cmp(&(b.0, &b.1))); for (_, _, subcommand) in ord_v { - if !first { + if !*first { self.writer.push_str("\n\n"); } - first = false; + *first = false; let heading = subcommand.get_usage_name_fallback(); let about = cmd @@ -937,6 +938,9 @@ impl<'cmd, 'writer> HelpTemplate<'cmd, 'writer> { .filter(|arg| should_show_arg(self.use_long, arg) && !arg.is_global_set()) .collect::>(); sub_help.write_args(&args, heading, option_sort_key); + if subcommand.is_flatten_help_set() { + sub_help.write_flat_subcommands(subcommand, first); + } } } diff --git a/tests/builder/help.rs b/tests/builder/help.rs index 3695056fecab..e8fd22cc696c 100644 --- a/tests/builder/help.rs +++ b/tests/builder/help.rs @@ -3285,6 +3285,44 @@ parent child1: --child1 -h, --help Print help +parent child1 grandchild1: +some 1 + --grandchild1 + -h, --help Print help + +parent child1 grandchild1 greatgrandchild1: +some 1 + --greatgrandchild1 + -h, --help Print help + +parent child1 grandchild1 greatgrandchild2: +some 1 + --greatgrandchild2 + -h, --help Print help + +parent child1 grandchild1 greatgrandchild3: +some 1 + --greatgrandchild3 + -h, --help Print help + +parent child1 grandchild1 help: +some 1 + + +parent child1 grandchild2: +some 1 + --grandchild2 + -h, --help Print help + +parent child1 grandchild3: +some 1 + --grandchild3 + -h, --help Print help + +parent child1 help: +some 1 + + parent child2: --child2 -h, --help Print help