summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJesse Duffield <jessedduffield@gmail.com>2024-01-28 11:46:20 +1100
committerJesse Duffield <jessedduffield@gmail.com>2024-01-28 11:48:21 +1100
commite1aa68a7bd49370ba89368432a5540947d705c18 (patch)
treee9b2953eca67f4e4f39f8f7af2ca24b347de321e
parentcf5d4d4f8e2df4fef529edf17be14f71497803ea (diff)
Warn users when attempting to cherry pick with old key
I wrote this feature and even I sometimes use the wrong key so I want to make this very clear to users so that there's no confusion
-rw-r--r--pkg/gui/controllers/basic_commits_controller.go18
-rw-r--r--pkg/i18n/english.go3
2 files changed, 21 insertions, 0 deletions
diff --git a/pkg/gui/controllers/basic_commits_controller.go b/pkg/gui/controllers/basic_commits_controller.go
index 45239ef68..5a4e4190e 100644
--- a/pkg/gui/controllers/basic_commits_controller.go
+++ b/pkg/gui/controllers/basic_commits_controller.go
@@ -106,6 +106,14 @@ func (self *BasicCommitsController) GetKeybindings(opts types.KeybindingsOpts) [
GetDisabledReason: self.require(self.singleItemSelected()),
Description: self.c.Tr.OpenDiffTool,
},
+ // Putting this at the bottom of the list so that it has the lowest priority,
+ // meaning that if the user has configured another keybinding to the same key
+ // then that will take precedence.
+ {
+ // Hardcoding this key because it's not configurable
+ Key: opts.GetKey("c"),
+ Handler: self.handleOldCherryPickKey,
+ },
}
return bindings
@@ -284,6 +292,16 @@ func (self *BasicCommitsController) copyRange(*models.Commit) error {
return self.c.Helpers().CherryPick.CopyRange(self.context.GetCommits(), self.context)
}
+func (self *BasicCommitsController) handleOldCherryPickKey() error {
+ msg := utils.ResolvePlaceholderString(self.c.Tr.OldCherryPickKeyWarning,
+ map[string]string{
+ "copy": keybindings.Label(self.c.UserConfig.Keybinding.Commits.CherryPickCopy),
+ "paste": keybindings.Label(self.c.UserConfig.Keybinding.Commits.PasteCommits),
+ })
+
+ return self.c.ErrorMsg(msg)
+}
+
func (self *BasicCommitsController) openDiffTool(commit *models.Commit) error {
to := commit.RefName()
from, reverse := self.c.Modes().Diffing.GetFromAndReverseArgsForDiff(commit.ParentRefName())
diff --git a/pkg/i18n/english.go b/pkg/i18n/english.go
index b5c1e977e..7d4c60c26 100644
--- a/pkg/i18n/english.go
+++ b/pkg/i18n/english.go
@@ -753,6 +753,7 @@ type TranslationSet struct {
NoItemSelected string
SelectedItemIsNotABranch string
RangeSelectNotSupportedForSubmodules string
+ OldCherryPickKeyWarning string
Actions Actions
Bisect Bisect
Log Log
@@ -1685,6 +1686,8 @@ func EnglishTranslationSet() TranslationSet {
NoItemSelected: "No item selected",
SelectedItemIsNotABranch: "Selected item is not a branch",
RangeSelectNotSupportedForSubmodules: "Range select not supported for submodules",
+ OldCherryPickKeyWarning: "The 'c' key is no longer the default key for copying commits to cherry pick. Please use `{{.copy}}` instead (and `{{.paste}}` to paste). The reason for this change is that the 'v' key for selecting a range of lines when staging is now also used for selecting a range of lines in any list view, meaning that we needed to find a new key for pasting commits, and if we're going to now use `{{.paste}}` for pasting commits, we may as well use `{{.copy}}` for copying them. If you want to configure the keybindings to get the old behaviour, set the following in your config:\n\nkeybinding:\n universal:\n toggleRangeSelect: <something other than v>\n commits:\n cherryPickCopy: 'c'\n pasteCommits: 'v'",
+
Actions: Actions{
// TODO: combine this with the original keybinding descriptions (those are all in lowercase atm)
CheckoutCommit: "Checkout commit",