From 6f4522e34a17fd2a320b3045e0ad95668f8db021 Mon Sep 17 00:00:00 2001 From: Yuya Nishihara Date: Sun, 5 Feb 2023 18:31:45 +0900 Subject: [PATCH] cli: move MergeArgsNotConfigured to ExternalToolError Even though this is an error specific to merge operation, I think it's rather a tool-level error than conflict resolution. --- src/merge_tools.rs | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/src/merge_tools.rs b/src/merge_tools.rs index 68c569b24..df609faae 100644 --- a/src/merge_tools.rs +++ b/src/merge_tools.rs @@ -41,6 +41,11 @@ use crate::ui::Ui; pub enum ExternalToolError { #[error("Invalid config: {0}")] ConfigError(#[from] ConfigError), + #[error( + "To use `{tool_name}` as a merge tool, the config `merge-tools.{tool_name}.merge-args` \ + must be defined (see docs for details)" + )] + MergeArgsNotConfigured { tool_name: String }, #[error("Error setting up temporary directory: {0:?}")] SetUpDirError(#[source] std::io::Error), // TODO: Remove the "(run with --verbose to see the exact invocation)" @@ -79,11 +84,6 @@ pub enum DiffEditError { pub enum ConflictResolveError { #[error(transparent)] ExternalToolError(#[from] ExternalToolError), - #[error( - "To use `{tool_name}` as a merge tool, the config `merge-tools.{tool_name}.merge-args` \ - must be defined (see docs for details)" - )] - MergeArgsNotConfigured { tool_name: String }, #[error("Couldn't find the path {0:?} in this revision")] PathNotFoundError(RepoPath), #[error("Couldn't find any conflicts at {0:?} in this revision")] @@ -449,11 +449,11 @@ fn get_diff_editor_from_settings( fn get_merge_tool_from_settings( ui: &mut Ui, settings: &UserSettings, -) -> Result { +) -> Result { let editor_name = editor_name_from_settings(ui, settings, "ui.merge-editor")?; - let editor = get_tool_config(settings, &editor_name).map_err(ExternalToolError::ConfigError)?; + let editor = get_tool_config(settings, &editor_name)?; if editor.merge_args.is_empty() { - Err(ConflictResolveError::MergeArgsNotConfigured { + Err(ExternalToolError::MergeArgsNotConfigured { tool_name: editor_name, }) } else {