From 57c554b75ca3dbe141748879ee3ed3512670b7e0 Mon Sep 17 00:00:00 2001 From: Yuya Nishihara Date: Wed, 18 Jan 2023 10:34:21 +0900 Subject: [PATCH] cli: fix panic on invalid git.fetch/push config value The default could be overridden by invalid value. --- src/commands.rs | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/src/commands.rs b/src/commands.rs index 025248eee..d777f7f02 100644 --- a/src/commands.rs +++ b/src/commands.rs @@ -3901,10 +3901,11 @@ fn cmd_git_fetch( args: &GitFetchArgs, ) -> Result<(), CommandError> { let mut workspace_command = command.workspace_helper(ui)?; - let remote = args - .remote - .clone() - .unwrap_or_else(|| command.settings().config().get("git.fetch").unwrap()); + let remote = if let Some(name) = &args.remote { + name.clone() + } else { + command.settings().config().get("git.fetch")? + }; let repo = workspace_command.repo(); let git_repo = get_git_repo(repo.store())?; let mut tx = workspace_command.start_transaction(&format!("fetch from git remote {}", &remote)); @@ -4158,10 +4159,11 @@ fn cmd_git_push( args: &GitPushArgs, ) -> Result<(), CommandError> { let mut workspace_command = command.workspace_helper(ui)?; - let remote = args - .remote - .clone() - .unwrap_or_else(|| command.settings().config().get("git.push").unwrap()); + let remote = if let Some(name) = &args.remote { + name.clone() + } else { + command.settings().config().get("git.push")? + }; let mut tx; let mut branch_updates = vec![]; let mut seen_branches = hashset! {};