Skip to content

Commit

Permalink
Merge pull request #250 from kbknapp/new-benches
Browse files Browse the repository at this point in the history
PRs accepted out of order
  • Loading branch information
James McGlashan committed Sep 11, 2015
2 parents 400af3c + 1316d21 commit f76e4fd
Show file tree
Hide file tree
Showing 2 changed files with 35 additions and 29 deletions.
62 changes: 34 additions & 28 deletions benches/03_complex.rs
Original file line number Diff line number Diff line change
Expand Up @@ -135,34 +135,40 @@ fn create_app_builder(b: &mut Bencher) {
});
}

// #[bench]
// fn create_app_macros(b: &mut Bencher) {
// b.iter(|| {
// clap_app!(claptests =>
// (version: "0.1")
// (about: "tests clap library")
// (author: "Kevin K. <[email protected]>")
// (@arg opt: -o --option +takes_value ... "tests options")
// (@arg positional: [positional] "tests positionals")
// (@arg flag: -f --flag ... +global "tests flags")
// (@arg flag2: -F conflicts_with[flag] requires[option2] "tests flags with exclusions")
// (@arg option2: --long-option-2 conflicts_with[option] requires[positional2] "tests long options with exclusions")
// (@arg positional2: [positional2] "tests positionals with exclusions")
// (@arg option3: -O --Option +takes_value possible_values[fast, slow] "tests options with specific value sets")
// (@arg positional3: [positional3] ... possible_values[vi, emacs] "tests positionals with specific values")
// (@arg multvals: --multvals +takes_value value_names[one, two] "Tests mutliple values, not mult occs")
// (@arg multvalsmo: --multvalsmo ... +takes_value value_names[one, two] "Tests mutliple values, not mult occs")
// (@arg minvals: --minvals2 min_values(1) ... +takes_value "Tests 2 min vals")
// (@arg maxvals: --maxvals3 ... +takes_value max_values(3) "Tests 3 max vals")
// (@subcommand subcmd =>
// (about: "tests subcommands")
// (version: "0.1")
// (author: "Kevin K. <[email protected]>")
// (@arg scoption: -o --option ... +takes_value "tests options")
// (@arg scpositional: [scpositional] "tests positionals"))
// );
// });
// }
#[bench]
fn create_app_macros(b: &mut Bencher) {
b.iter(|| {
clap_app!(claptests =>
(version: "0.1")
(about: "tests clap library")
(author: "Kevin K. <[email protected]>")
(@arg opt: -o --option +takes_value ... "tests options")
(@arg positional: index(1) "tests positionals")
(@arg flag: -f --flag ... +global "tests flags")
(@arg flag2: -F conflicts_with[flag] requires[option2]
"tests flags with exclusions")
(@arg option2: --long_option_2 conflicts_with[option] requires[positional2]
"tests long options with exclusions")
(@arg positional2: index(2) "tests positionals with exclusions")
(@arg option3: -O --Option +takes_value possible_value[fast slow]
"tests options with specific value sets")
(@arg positional3: index(3) ... possible_value[vi emacs]
"tests positionals with specific values")
(@arg multvals: --multvals +takes_value value_name[one two]
"Tests mutliple values, not mult occs")
(@arg multvalsmo: --multvalsmo ... +takes_value value_name[one two]
"Tests mutliple values, not mult occs")
(@arg minvals: --minvals2 min_values(1) ... +takes_value "Tests 2 min vals")
(@arg maxvals: --maxvals3 ... +takes_value max_values(3) "Tests 3 max vals")
(@subcommand subcmd =>
(about: "tests subcommands")
(version: "0.1")
(author: "Kevin K. <[email protected]>")
(@arg scoption: -o --option ... +takes_value "tests options")
(@arg scpositional: index(1) "tests positionals"))
);
});
}

#[bench]
fn parse_clean(b: &mut Bencher) {
Expand Down
2 changes: 1 addition & 1 deletion src/macros.rs
Original file line number Diff line number Diff line change
Expand Up @@ -813,7 +813,7 @@ macro_rules! clap_app {
clap_app!{ @arg ($arg.value_name(stringify!($var))) (+) $($tail)* }
};
(@arg ($arg:expr) (-) [$var:ident] $($tail:tt)*) => {
clap_app!{ @arg ($arg.value_name(stringify!($var))) +takes_value (+) $($tail)* }
clap_app!{ @arg ($arg.value_name(stringify!($var))) (+) +takes_value $($tail)* }
};
(@arg ($arg:expr) (+) [$var:ident] $($tail:tt)*) => {
clap_app!{ @arg ($arg.value_name(stringify!($var))) (+) $($tail)* }
Expand Down

0 comments on commit f76e4fd

Please sign in to comment.