Skip to content

Commit

Permalink
fix(usage strings): positional arguments are presented in index order
Browse files Browse the repository at this point in the history
Positional arguments are now presented in index order in suggested usage
strings which prevents out of order suggestions.

Closes #112
  • Loading branch information
kbknapp committed May 8, 2015
1 parent 4903add commit eb0e374
Showing 1 changed file with 9 additions and 6 deletions.
15 changes: 9 additions & 6 deletions src/app.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ use std::collections::BTreeMap;
use std::collections::BTreeSet;
use std::collections::HashSet;
use std::collections::HashMap;
use std::collections::VecDeque;
use std::env;
use std::path::Path;
use std::vec::IntoIter;
Expand Down Expand Up @@ -765,7 +766,7 @@ impl<'a, 'v, 'ab, 'u, 'h, 'ar> App<'a, 'v, 'ab, 'u, 'h, 'ar>{
.fold(vec![], |acc, v| acc + &v)
}

fn get_required_from(&self, reqs: HashSet<&'ar str>) -> Vec<String> {
fn get_required_from(&self, reqs: HashSet<&'ar str>) -> VecDeque<String> {
let mut c_flags = HashSet::new();
let mut c_pos = HashSet::new();
let mut c_opt = HashSet::new();
Expand Down Expand Up @@ -852,27 +853,29 @@ impl<'a, 'v, 'ab, 'u, 'h, 'ar> App<'a, 'v, 'ab, 'u, 'h, 'ar>{
}


let mut ret_val = vec![];
let mut ret_val = VecDeque::new();

let mut pmap = BTreeMap::new();
for p in &c_pos {
if let Some(idx) = self.positionals_name.get(p) {
if let Some(ref p) = self.positionals_idx.get(&idx) {
ret_val.push(format!("{}", p));
pmap.insert(p.index, format!("{}", p));
}
}
}
pmap.into_iter().map(|(_, s)| ret_val.push_back(s)).collect::<Vec<_>>();
for f in &c_flags {
ret_val.push(format!("{}", self.flags.get(*f).unwrap()));
ret_val.push_back(format!("{}", self.flags.get(*f).unwrap()));
}
for o in &c_opt {
ret_val.push(format!("{}", self.opts.get(*o).unwrap()));
ret_val.push_back(format!("{}", self.opts.get(*o).unwrap()));
}
for g in grps {
let g_string = self.get_group_members(g).iter()
.fold(String::new(), |acc, s| {
acc + &format!(" {} |",s)[..]
});
ret_val.push(format!("[{}]", &g_string[..g_string.len()-1]));
ret_val.push_back(format!("[{}]", &g_string[..g_string.len()-1]));
}

ret_val
Expand Down

0 comments on commit eb0e374

Please sign in to comment.