From 3dd8b9a5f0976a2a5e6f3f892818019d9a9bcc6b Mon Sep 17 00:00:00 2001 From: Yuya Nishihara Date: Wed, 22 Feb 2023 19:47:52 +0900 Subject: [PATCH] cli: extract update_working_copy() from finish_transaction() I'll move some bits from the free update_working_copy() function to deduplicate parse_commit_summary_template() call. --- src/cli_util.rs | 48 +++++++++++++++++++++++++++++------------------- 1 file changed, 29 insertions(+), 19 deletions(-) diff --git a/src/cli_util.rs b/src/cli_util.rs index 935d348d7..9ce648895 100644 --- a/src/cli_util.rs +++ b/src/cli_util.rs @@ -947,6 +947,34 @@ impl WorkspaceCommandHelper { Ok(()) } + fn update_working_copy( + &mut self, + ui: &mut Ui, + maybe_old_commit: Option<&Commit>, + ) -> Result<(), CommandError> { + assert!(self.may_update_working_copy); + let workspace_id = self.workspace_id().to_owned(); + let summary_template = parse_commit_summary_template( + &self.repo, + &workspace_id, + &self.template_aliases_map, + &self.settings, + ) + .expect("parse error should be confined by WorkspaceCommandHelper::new()"); + let stats = update_working_copy( + ui, + &self.repo, + &workspace_id, + self.workspace.working_copy_mut(), + maybe_old_commit, + &summary_template, + )?; + if let Some(stats) = stats { + print_checkout_stats(ui, stats)?; + } + Ok(()) + } + pub fn start_transaction(&mut self, description: &str) -> WorkspaceCommandTransaction { let tx = start_repo_transaction(&self.repo, &self.settings, &self.string_args, description); WorkspaceCommandTransaction { helper: self, tx } @@ -977,25 +1005,7 @@ impl WorkspaceCommandHelper { .transpose()?; self.repo = tx.commit(); if self.may_update_working_copy { - let workspace_id = self.workspace_id().to_owned(); - let summary_template = parse_commit_summary_template( - &self.repo, - &workspace_id, - &self.template_aliases_map, - &self.settings, - ) - .expect("parse error should be confined by WorkspaceCommandHelper::new()"); - let stats = update_working_copy( - ui, - &self.repo, - &workspace_id, - self.workspace.working_copy_mut(), - maybe_old_commit.as_ref(), - &summary_template, - )?; - if let Some(stats) = stats { - print_checkout_stats(ui, stats)?; - } + self.update_working_copy(ui, maybe_old_commit.as_ref())?; } let settings = &self.settings; if settings.user_name() == UserSettings::user_name_placeholder()