// Hi, future me (or whoever you are)! // // Yes, we do need this attr. // No, the warnings cannot be fixed otherwise. // Accept and endure. Do not touch. #![allow(unused)] use clap::CommandFactory; pub const FULL_TEMPLATE: &str = "\ {before-help}{name} {version} {author-with-newline}{about-with-newline} {usage-heading} {usage} {all-args}{after-help}"; pub fn get_help() -> String { let output = ::command().render_help().to_string(); eprintln!("\n%%% HELP %%%:=====\n{}\n=====\n", output); eprintln!("\n%%% HELP (DEBUG) %%%:=====\n{:?}\n=====\n", output); output } pub fn get_long_help() -> String { let output = ::command() .render_long_help() .to_string(); eprintln!("\n%%% LONG_HELP %%%:=====\n{}\n=====\n", output); eprintln!("\n%%% LONG_HELP (DEBUG) %%%:=====\n{:?}\n=====\n", output); output } pub fn get_subcommand_long_help(subcmd: &str) -> String { let output = ::command() .get_subcommands_mut() .find(|s| s.get_name() == subcmd) .unwrap() .render_long_help() .to_string(); eprintln!( "\n%%% SUBCOMMAND `{}` HELP %%%:=====\n{}\n=====\n", subcmd, output ); eprintln!( "\n%%% SUBCOMMAND `{}` HELP (DEBUG) %%%:=====\n{:?}\n=====\n", subcmd, output ); output }