From 7c4b16f6ae088be3069e25185a950ac0a772c786 Mon Sep 17 00:00:00 2001 From: tippfehlr Date: Fri, 17 Mar 2023 22:58:26 +0100 Subject: [PATCH] add `-l/--less` option to `ferium upgrade` to hide compatible mods --- src/cli.rs | 8 ++++++-- src/main.rs | 4 ++-- src/subcommands/upgrade.rs | 25 ++++++++++++++----------- 3 files changed, 22 insertions(+), 15 deletions(-) diff --git a/src/cli.rs b/src/cli.rs index 29f28ac..a7ff579 100644 --- a/src/cli.rs +++ b/src/cli.rs @@ -90,8 +90,12 @@ pub enum SubCommands { /// List of project IDs or case-insensitive names of mods to remove mod_names: Vec, }, - /// Download and install the latest compatible version of your mods - Upgrade, + /// Download and install the latest version of the mods specified + Upgrade { + #[clap(long, short)] + /// Don’t print compatible mods + less: bool, + }, } #[derive(Subcommand)] diff --git a/src/main.rs b/src/main.rs index 5543d64..fba589c 100644 --- a/src/main.rs +++ b/src/main.rs @@ -387,11 +387,11 @@ async fn actual_main(cli_app: Ferium) -> Result<()> { check_empty_profile(profile)?; subcommands::remove(profile, mod_names)?; } - SubCommands::Upgrade => { + SubCommands::Upgrade { less } => { check_internet().await?; let profile = get_active_profile(&mut config)?; check_empty_profile(profile)?; - subcommands::upgrade(modrinth, curseforge, github, profile).await?; + subcommands::upgrade(modrinth, curseforge, github, profile, less).await?; } }; diff --git a/src/subcommands/upgrade.rs b/src/subcommands/upgrade.rs index 4a134df..631c22a 100644 --- a/src/subcommands/upgrade.rs +++ b/src/subcommands/upgrade.rs @@ -61,6 +61,7 @@ pub async fn get_platform_downloadables( curseforge: Furse, github: Octocrab, profile: &Profile, + less: bool, ) -> Result<(Vec, bool)> { let to_download = Arc::new(Mutex::new(Vec::new())); let progress_bar = Arc::new(Mutex::new( @@ -72,7 +73,7 @@ pub async fn get_platform_downloadables( let modrinth = Arc::new(modrinth); let github = Arc::new(github); - println!("{}\n", "Determining the Latest Compatible Versions".bold()); + println!("{}", "Determining the Latest Compatible Versions".bold()); let semaphore = Arc::new(Semaphore::new(75)); progress_bar .lock() @@ -144,16 +145,18 @@ pub async fn get_platform_downloadables( progress_bar.inc(1); match result { Ok((downloadable, backwards_compat)) => { - progress_bar.println(format!( - "{} {:43} {}", - if backwards_compat { - YELLOW_TICK.clone() - } else { - TICK.clone() - }, - mod_.name, - downloadable.filename().dimmed() - )); + if !less { + progress_bar.println(format!( + "{} {:43} {}", + if backwards_compat { + YELLOW_TICK.clone() + } else { + TICK.clone() + }, + mod_.name, + downloadable.filename().dimmed() + )); + } { to_download .lock()