summaryrefslogtreecommitdiff
path: root/cli/tools/upgrade.rs
diff options
context:
space:
mode:
Diffstat (limited to 'cli/tools/upgrade.rs')
-rw-r--r--cli/tools/upgrade.rs15
1 files changed, 10 insertions, 5 deletions
diff --git a/cli/tools/upgrade.rs b/cli/tools/upgrade.rs
index fd8394efa..8349f060c 100644
--- a/cli/tools/upgrade.rs
+++ b/cli/tools/upgrade.rs
@@ -371,15 +371,20 @@ async fn fetch_and_store_latest_version<
}
pub async fn upgrade(
- flags: Flags,
+ flags: Arc<Flags>,
upgrade_flags: UpgradeFlags,
) -> Result<(), AnyError> {
- let factory = CliFactory::from_flags(flags)?;
+ let factory = CliFactory::from_flags(flags);
let client = factory.http_client_provider().get_or_create()?;
let current_exe_path = std::env::current_exe()?;
- let full_path_output_flag = upgrade_flags
- .output
- .map(|output| factory.cli_options().initial_cwd().join(output));
+ let full_path_output_flag = match &upgrade_flags.output {
+ Some(output) => Some(
+ std::env::current_dir()
+ .context("failed getting cwd")?
+ .join(output),
+ ),
+ None => None,
+ };
let output_exe_path =
full_path_output_flag.as_ref().unwrap_or(&current_exe_path);