mirror of
https://github.com/clap-rs/clap
synced 2025-01-18 23:53:54 +00:00
feat: allows setting version number to auto-propagate through subcommands
The version number can now be auto-propgated down through subcommands with the App::global_version(true) method Closes #157
This commit is contained in:
parent
8889689dc6
commit
bc66d3c6de
1 changed files with 34 additions and 8 deletions
42
src/app.rs
42
src/app.rs
|
@ -99,12 +99,8 @@ pub struct App<'a, 'v, 'ab, 'u, 'h, 'ar> {
|
||||||
positionals_name: HashMap<&'ar str, u8>,
|
positionals_name: HashMap<&'ar str, u8>,
|
||||||
// A list of subcommands
|
// A list of subcommands
|
||||||
subcommands: BTreeMap<String, App<'a, 'v, 'ab, 'u, 'h, 'ar>>,
|
subcommands: BTreeMap<String, App<'a, 'v, 'ab, 'u, 'h, 'ar>>,
|
||||||
needs_long_help: bool,
|
|
||||||
needs_long_version: bool,
|
|
||||||
help_short: Option<char>,
|
help_short: Option<char>,
|
||||||
version_short: Option<char>,
|
version_short: Option<char>,
|
||||||
needs_subcmd_help: bool,
|
|
||||||
subcmds_neg_reqs: bool,
|
|
||||||
required: HashSet<&'ar str>,
|
required: HashSet<&'ar str>,
|
||||||
short_list: HashSet<char>,
|
short_list: HashSet<char>,
|
||||||
long_list: HashSet<&'ar str>,
|
long_list: HashSet<&'ar str>,
|
||||||
|
@ -114,11 +110,16 @@ pub struct App<'a, 'v, 'ab, 'u, 'h, 'ar> {
|
||||||
usage: Option<String>,
|
usage: Option<String>,
|
||||||
groups: HashMap<&'ar str, ArgGroup<'ar, 'ar>>,
|
groups: HashMap<&'ar str, ArgGroup<'ar, 'ar>>,
|
||||||
global_args: Vec<Arg<'ar, 'ar, 'ar, 'ar, 'ar, 'ar>>,
|
global_args: Vec<Arg<'ar, 'ar, 'ar, 'ar, 'ar, 'ar>>,
|
||||||
|
help_str: Option<&'u str>,
|
||||||
no_sc_error: bool,
|
no_sc_error: bool,
|
||||||
wait_on_error: bool,
|
wait_on_error: bool,
|
||||||
help_on_no_args: bool,
|
help_on_no_args: bool,
|
||||||
help_str: Option<&'u str>,
|
needs_long_help: bool,
|
||||||
help_on_no_sc: bool
|
needs_long_version: bool,
|
||||||
|
needs_subcmd_help: bool,
|
||||||
|
subcmds_neg_reqs: bool,
|
||||||
|
help_on_no_sc: bool,
|
||||||
|
global_ver: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a, 'v, 'ab, 'u, 'h, 'ar> App<'a, 'v, 'ab, 'u, 'h, 'ar>{
|
impl<'a, 'v, 'ab, 'u, 'h, 'ar> App<'a, 'v, 'ab, 'u, 'h, 'ar>{
|
||||||
|
@ -166,7 +167,8 @@ impl<'a, 'v, 'ab, 'u, 'h, 'ar> App<'a, 'v, 'ab, 'u, 'h, 'ar>{
|
||||||
help_str: None,
|
help_str: None,
|
||||||
wait_on_error: false,
|
wait_on_error: false,
|
||||||
help_on_no_args: false,
|
help_on_no_args: false,
|
||||||
help_on_no_sc: false
|
help_on_no_sc: false,
|
||||||
|
global_ver: false,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -421,6 +423,27 @@ impl<'a, 'v, 'ab, 'u, 'h, 'ar> App<'a, 'v, 'ab, 'u, 'h, 'ar>{
|
||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Uses version of the current command for all subcommands.
|
||||||
|
///
|
||||||
|
/// **NOTE:** The version for the current command must be set **prior** adding any subcommands
|
||||||
|
///
|
||||||
|
/// # Example
|
||||||
|
///
|
||||||
|
/// ```no_run
|
||||||
|
/// # use clap::{App, Arg, SubCommand};
|
||||||
|
/// App::new("myprog")
|
||||||
|
/// .version("v1.1")
|
||||||
|
/// .global_version(true)
|
||||||
|
/// .subcommand(SubCommand::with_name("test"))
|
||||||
|
/// .get_matches();
|
||||||
|
/// // running `myprog test --version` will display
|
||||||
|
/// // "myprog-test v1.1"
|
||||||
|
/// ```
|
||||||
|
pub fn global_version(mut self, gv: bool) -> App<'a, 'v, 'ab, 'u, 'h, 'ar> {
|
||||||
|
self.global_ver = gv;
|
||||||
|
self
|
||||||
|
}
|
||||||
|
|
||||||
/// Will display a message "Press [ENTER]/[RETURN] to continue..." and wait user before
|
/// Will display a message "Press [ENTER]/[RETURN] to continue..." and wait user before
|
||||||
/// exiting
|
/// exiting
|
||||||
///
|
///
|
||||||
|
@ -927,9 +950,12 @@ impl<'a, 'v, 'ab, 'u, 'h, 'ar> App<'a, 'v, 'ab, 'u, 'h, 'ar>{
|
||||||
/// // Additional subcommand configuration goes here, such as other arguments...
|
/// // Additional subcommand configuration goes here, such as other arguments...
|
||||||
/// # ;
|
/// # ;
|
||||||
/// ```
|
/// ```
|
||||||
pub fn subcommand(mut self, subcmd: App<'a, 'v, 'ab, 'u, 'h, 'ar>)
|
pub fn subcommand(mut self, mut subcmd: App<'a, 'v, 'ab, 'u, 'h, 'ar>)
|
||||||
-> App<'a, 'v, 'ab, 'u, 'h, 'ar> {
|
-> App<'a, 'v, 'ab, 'u, 'h, 'ar> {
|
||||||
if subcmd.name == "help" { self.needs_subcmd_help = false; }
|
if subcmd.name == "help" { self.needs_subcmd_help = false; }
|
||||||
|
if self.global_ver && subcmd.version.is_none() && self.version.is_some() {
|
||||||
|
subcmd.version = Some(self.version.unwrap());
|
||||||
|
}
|
||||||
self.subcommands.insert(subcmd.name.clone(), subcmd);
|
self.subcommands.insert(subcmd.name.clone(), subcmd);
|
||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue