From aaf0d6fe7aa2403e76096c16204d254a9ee61ee2 Mon Sep 17 00:00:00 2001 From: Kevin K Date: Thu, 1 Oct 2015 12:33:37 -0400 Subject: [PATCH] fix(Usage Strings): fixes a bug ordering of elements in usage strings Closes #298 --- src/app/app.rs | 13 ++++++++----- 1 file changed, 8 insertions(+), 5 deletions(-) diff --git a/src/app/app.rs b/src/app/app.rs index b7107a16..ae6b858b 100644 --- a/src/app/app.rs +++ b/src/app/app.rs @@ -1325,7 +1325,6 @@ impl<'a, 'v, 'ab, 'u, 'h, 'ar> App<'a, 'v, 'ab, 'u, 'h, 'ar>{ acc + &format!(" {}", s)[..] }); - if !self.flags.is_empty() && !self.settings.is_set(&AppSettings::UnifiedHelpMessage) { usage.push_str(" [FLAGS]"); } else { @@ -1335,11 +1334,16 @@ impl<'a, 'v, 'ab, 'u, 'h, 'ar> App<'a, 'v, 'ab, 'u, 'h, 'ar>{ self.opts.values().any(|a| !a.settings.is_set(&ArgSettings::Required)) { usage.push_str(" [OPTIONS]"); } + + usage.push_str(&req_string[..]); + // places a '--' in the usage string if there are args and options // supporting multiple values - if !self.positionals_idx.is_empty() && self.opts.values().any(|a| a.settings.is_set(&ArgSettings::Multiple)) && - !self.opts.values().any(|a| a.settings.is_set(&ArgSettings::Required)) && - self.subcommands.is_empty() { + if !self.positionals_idx.is_empty() && + (self.opts.values().any(|a| a.settings.is_set(&ArgSettings::Multiple)) || + self.positionals_idx.values().any(|a| a.settings.is_set(&ArgSettings::Multiple))) && + !self.opts.values().any(|a| a.settings.is_set(&ArgSettings::Required)) && + self.subcommands.is_empty() { usage.push_str(" [--]") } if !self.positionals_idx.is_empty() && @@ -1348,7 +1352,6 @@ impl<'a, 'v, 'ab, 'u, 'h, 'ar> App<'a, 'v, 'ab, 'u, 'h, 'ar>{ usage.push_str(" [ARGS]"); } - usage.push_str(&req_string[..]); if !self.subcommands.is_empty() && !self.settings.is_set(&AppSettings::SubcommandRequired) { usage.push_str(" [SUBCOMMAND]");