Skip to content

Commit

Permalink
fix: Clarify some unwraps as expects
Browse files Browse the repository at this point in the history
This was inspiredby clap-rs#3322
  • Loading branch information
epage committed Jan 21, 2022
1 parent ddad3a7 commit b488aab
Show file tree
Hide file tree
Showing 5 changed files with 33 additions and 12 deletions.
4 changes: 3 additions & 1 deletion clap_complete/src/shells/bash.rs
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,9 @@ impl Generator for Bash {
}

fn generate(&self, app: &App, buf: &mut dyn Write) {
let bin_name = app.get_bin_name().unwrap();
let bin_name = app
.get_bin_name()
.expect("crate::generate should have set the bin_name");

w!(
buf,
Expand Down
4 changes: 3 additions & 1 deletion clap_complete/src/shells/elvish.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,9 @@ impl Generator for Elvish {
}

fn generate(&self, app: &App, buf: &mut dyn Write) {
let bin_name = app.get_bin_name().unwrap();
let bin_name = app
.get_bin_name()
.expect("crate::generate should have set the bin_name");

let mut names = vec![];
let subcommands_cases = generate_inner(app, "", &mut names);
Expand Down
8 changes: 5 additions & 3 deletions clap_complete/src/shells/fish.rs
Original file line number Diff line number Diff line change
Expand Up @@ -16,10 +16,12 @@ impl Generator for Fish {
}

fn generate(&self, app: &App, buf: &mut dyn Write) {
let command = app.get_bin_name().unwrap();
let mut buffer = String::new();
let bin_name = app
.get_bin_name()
.expect("crate::generate should have set the bin_name");

gen_fish_inner(command, &[], app, &mut buffer);
let mut buffer = String::new();
gen_fish_inner(bin_name, &[], app, &mut buffer);
w!(buf, buffer.as_bytes());
}
}
Expand Down
4 changes: 3 additions & 1 deletion clap_complete/src/shells/powershell.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,9 @@ impl Generator for PowerShell {
}

fn generate(&self, app: &App, buf: &mut dyn Write) {
let bin_name = app.get_bin_name().unwrap();
let bin_name = app
.get_bin_name()
.expect("crate::generate should have set the bin_name");

let mut names = vec![];
let subcommands_cases = generate_inner(app, "", &mut names);
Expand Down
25 changes: 19 additions & 6 deletions clap_complete/src/shells/zsh.rs
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,10 @@ impl Generator for Zsh {
}

fn generate(&self, app: &App, buf: &mut dyn Write) {
let bin_name = app
.get_bin_name()
.expect("crate::generate should have set the bin_name");

w!(
buf,
format!(
Expand All @@ -41,7 +45,7 @@ _{name}() {{
_{name} \"$@\"
",
name = app.get_bin_name().unwrap(),
name = bin_name,
initial_args = get_args_of(app, None),
subcommands = get_subcommands_of(app),
subcommand_details = subcommand_details(app)
Expand Down Expand Up @@ -81,7 +85,9 @@ _{name} \"$@\"
fn subcommand_details(p: &App) -> String {
debug!("subcommand_details");

let name = p.get_bin_name().unwrap();
let bin_name = p
.get_bin_name()
.expect("crate::generate should have set the bin_name");

let mut ret = vec![];

Expand All @@ -93,8 +99,8 @@ _{bin_name_underscore}_commands() {{
local commands; commands=({subcommands_and_args})
_describe -t commands '{bin_name} commands' commands \"$@\"
}}",
bin_name_underscore = name.replace(' ', "__"),
bin_name = name,
bin_name_underscore = bin_name.replace(' ', "__"),
bin_name = bin_name,
subcommands_and_args = subcommands_of(p)
);
ret.push(parent_text);
Expand Down Expand Up @@ -247,6 +253,10 @@ fn get_subcommands_of(parent: &App) -> String {
all_subcommands.push(segments.join("\n"));
}

let parent_bin_name = parent
.get_bin_name()
.expect("crate::generate should have set the bin_name");

format!(
"
case $state in
Expand All @@ -260,7 +270,7 @@ fn get_subcommands_of(parent: &App) -> String {
;;
esac",
name = parent.get_name(),
name_hyphen = parent.get_bin_name().unwrap().replace(' ', "-"),
name_hyphen = parent_bin_name.replace(' ', "-"),
subcommands = all_subcommands.join("\n"),
pos = parent.get_positionals().count() + 1
)
Expand Down Expand Up @@ -327,9 +337,12 @@ fn get_args_of(parent: &App, p_global: Option<&App>) -> String {
}

if parent.has_subcommands() {
let parent_bin_name = parent
.get_bin_name()
.expect("crate::generate should have set the bin_name");
let subcommand_bin_name = format!(
"\":: :_{name}_commands\" \\",
name = parent.get_bin_name().as_ref().unwrap().replace(' ', "__")
name = parent_bin_name.replace(' ', "__")
);
segments.push(subcommand_bin_name);

Expand Down

0 comments on commit b488aab

Please sign in to comment.