Skip to content

Commit

Permalink
rage: Correctly handle extensions in the after-help text
Browse files Browse the repository at this point in the history
  • Loading branch information
str4d committed Jan 16, 2024
1 parent 201f21f commit 0cdeff1
Showing 1 changed file with 22 additions and 10 deletions.
32 changes: 22 additions & 10 deletions rage/src/bin/rage/cli.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,20 +4,32 @@ use clap::{builder::Styles, ArgAction, Parser};

use crate::fl;

fn binary_name() -> String {
fn binary_name(suffix: Option<&str>) -> String {
if let Some(arg) = std::env::args_os().next() {
Path::new(&arg)
.file_name()
.expect("is not directory")
.to_string_lossy()
.to_string()
let path = Path::new(&arg);
if let Some(suffix) = suffix {
let stem = path
.file_stem()
.expect("is not directory")
.to_string_lossy();
let extension = path
.extension()
.map(|extension| extension.to_string_lossy())
.unwrap_or_default();
format!("{}{}{}", stem, suffix, extension)
} else {
path.file_name()
.expect("is not directory")
.to_string_lossy()
.to_string()
}
} else {
"rage".into()
format!("rage{}", suffix.unwrap_or_default())
}
}

fn usage() -> String {
let binary_name = binary_name();
let binary_name = binary_name(None);
let recipient = fl!("recipient");
let identity = fl!("identity");
let input = fl!("input");
Expand All @@ -39,8 +51,8 @@ pub(crate) fn after_help_content(keygen_name: &str) -> String {
}

fn after_help() -> String {
let binary_name = binary_name();
let keygen_name = format!("{}-keygen", binary_name);
let keygen_name = binary_name(Some("-keygen"));
let binary_name = binary_name(None);
let example_a = format!("$ {} -o key.txt", keygen_name);
let example_a_output = "age1ql3z7hjy54pw3hyww5ayyfg7zqgvc7w3j2elw8zmrj2kg5sfn9aqmcac8p";
let example_b = format!(
Expand Down

0 comments on commit 0cdeff1

Please sign in to comment.