1
0
mirror of https://github.com/jesseduffield/lazygit.git synced 2025-01-26 05:37:18 +02:00
lazygit/pkg/gui/patch_options_panel.go

211 lines
5.9 KiB
Go
Raw Normal View History

package gui
import (
"fmt"
2021-12-30 13:35:10 +11:00
"github.com/jesseduffield/lazygit/pkg/commands/types/enums"
2022-01-29 19:15:46 +11:00
"github.com/jesseduffield/lazygit/pkg/gui/context"
2022-01-28 20:44:36 +11:00
"github.com/jesseduffield/lazygit/pkg/gui/types"
)
func (gui *Gui) handleCreatePatchOptionsMenu() error {
if !gui.git.Patch.PatchManager.Active() {
return gui.c.ErrorMsg(gui.c.Tr.NoPatchError)
}
2022-01-29 19:09:20 +11:00
menuItems := []*types.MenuItem{
2020-02-14 23:32:52 +11:00
{
2022-01-28 20:44:36 +11:00
DisplayString: "reset patch",
OnPress: gui.handleResetPatch,
Key: 'c',
},
2020-03-26 21:00:08 +11:00
{
2022-01-28 20:44:36 +11:00
DisplayString: "apply patch",
OnPress: func() error { return gui.handleApplyPatch(false) },
Key: 'a',
2020-03-30 08:49:20 +11:00
},
{
2022-01-28 20:44:36 +11:00
DisplayString: "apply patch in reverse",
OnPress: func() error { return gui.handleApplyPatch(true) },
Key: 'r',
2020-03-26 21:00:08 +11:00
},
}
if gui.git.Patch.PatchManager.CanRebase && gui.git.Status.WorkingTreeState() == enums.REBASE_MODE_NONE {
2022-01-29 19:09:20 +11:00
menuItems = append(menuItems, []*types.MenuItem{
{
DisplayString: fmt.Sprintf("remove patch from original commit (%s)", gui.git.Patch.PatchManager.To),
2022-01-28 20:44:36 +11:00
OnPress: gui.handleDeletePatchFromCommit,
Key: 'd',
},
{
2022-01-28 20:44:36 +11:00
DisplayString: "move patch out into index",
OnPress: gui.handleMovePatchIntoWorkingTree,
Key: 'i',
},
{
2022-01-28 20:44:36 +11:00
DisplayString: "move patch into new commit",
OnPress: gui.handlePullPatchIntoNewCommit,
Key: 'n',
},
}...)
2022-02-13 17:01:53 +11:00
if gui.currentContext().GetKey() == gui.State.Contexts.LocalCommits.GetKey() {
selectedCommit := gui.getSelectedLocalCommit()
if selectedCommit != nil && gui.git.Patch.PatchManager.To != selectedCommit.Sha {
2020-08-21 20:54:09 +10:00
// adding this option to index 1
menuItems = append(
menuItems[:1],
append(
2022-01-29 19:09:20 +11:00
[]*types.MenuItem{
2020-08-21 20:54:09 +10:00
{
2022-01-28 20:44:36 +11:00
DisplayString: fmt.Sprintf("move patch to selected commit (%s)", selectedCommit.Sha),
OnPress: gui.handleMovePatchToSelectedCommit,
Key: 'm',
2020-08-21 20:54:09 +10:00
},
}, menuItems[1:]...,
)...,
)
}
2020-08-21 20:51:39 +10:00
}
}
2022-01-29 19:09:20 +11:00
return gui.c.Menu(types.CreateMenuOptions{Title: gui.c.Tr.PatchOptionsTitle, Items: menuItems})
}
func (gui *Gui) getPatchCommitIndex() int {
2022-01-31 22:11:34 +11:00
for index, commit := range gui.State.Model.Commits {
if commit.Sha == gui.git.Patch.PatchManager.To {
return index
}
}
return -1
}
func (gui *Gui) validateNormalWorkingTreeState() (bool, error) {
if gui.git.Status.WorkingTreeState() != enums.REBASE_MODE_NONE {
return false, gui.c.ErrorMsg(gui.c.Tr.CantPatchWhileRebasingError)
}
return true, nil
}
func (gui *Gui) returnFocusFromLineByLinePanelIfNecessary() error {
2022-01-29 19:15:46 +11:00
if gui.State.MainContext == context.MAIN_PATCH_BUILDING_CONTEXT_KEY {
2020-08-15 17:23:16 +10:00
return gui.handleEscapePatchBuildingPanel()
}
return nil
}
func (gui *Gui) handleDeletePatchFromCommit() error {
if ok, err := gui.validateNormalWorkingTreeState(); !ok {
return err
}
if err := gui.returnFocusFromLineByLinePanelIfNecessary(); err != nil {
return err
}
return gui.c.WithWaitingStatus(gui.c.Tr.RebasingStatus, func() error {
commitIndex := gui.getPatchCommitIndex()
gui.c.LogAction(gui.c.Tr.Actions.RemovePatchFromCommit)
2022-01-31 22:11:34 +11:00
err := gui.git.Patch.DeletePatchesFromCommit(gui.State.Model.Commits, commitIndex)
2022-02-06 15:54:26 +11:00
return gui.helpers.MergeAndRebase.CheckMergeOrRebase(err)
})
}
func (gui *Gui) handleMovePatchToSelectedCommit() error {
if ok, err := gui.validateNormalWorkingTreeState(); !ok {
return err
}
if err := gui.returnFocusFromLineByLinePanelIfNecessary(); err != nil {
return err
}
return gui.c.WithWaitingStatus(gui.c.Tr.RebasingStatus, func() error {
commitIndex := gui.getPatchCommitIndex()
gui.c.LogAction(gui.c.Tr.Actions.MovePatchToSelectedCommit)
2022-02-13 17:01:53 +11:00
err := gui.git.Patch.MovePatchToSelectedCommit(gui.State.Model.Commits, commitIndex, gui.State.Contexts.LocalCommits.GetSelectedLineIdx())
2022-02-06 15:54:26 +11:00
return gui.helpers.MergeAndRebase.CheckMergeOrRebase(err)
})
}
func (gui *Gui) handleMovePatchIntoWorkingTree() error {
if ok, err := gui.validateNormalWorkingTreeState(); !ok {
return err
}
if err := gui.returnFocusFromLineByLinePanelIfNecessary(); err != nil {
return err
}
pull := func(stash bool) error {
return gui.c.WithWaitingStatus(gui.c.Tr.RebasingStatus, func() error {
commitIndex := gui.getPatchCommitIndex()
gui.c.LogAction(gui.c.Tr.Actions.MovePatchIntoIndex)
2022-01-31 22:11:34 +11:00
err := gui.git.Patch.MovePatchIntoIndex(gui.State.Model.Commits, commitIndex, stash)
2022-02-06 15:54:26 +11:00
return gui.helpers.MergeAndRebase.CheckMergeOrRebase(err)
})
}
2022-01-31 22:11:34 +11:00
if gui.helpers.WorkingTree.IsWorkingTreeDirty() {
return gui.c.Confirm(types.ConfirmOpts{
Title: gui.c.Tr.MustStashTitle,
Prompt: gui.c.Tr.MustStashWarning,
2022-01-28 20:44:36 +11:00
HandleConfirm: func() error {
2020-08-15 16:36:39 +10:00
return pull(true)
},
})
} else {
return pull(false)
}
}
func (gui *Gui) handlePullPatchIntoNewCommit() error {
if ok, err := gui.validateNormalWorkingTreeState(); !ok {
return err
}
if err := gui.returnFocusFromLineByLinePanelIfNecessary(); err != nil {
return err
}
return gui.c.WithWaitingStatus(gui.c.Tr.RebasingStatus, func() error {
commitIndex := gui.getPatchCommitIndex()
gui.c.LogAction(gui.c.Tr.Actions.MovePatchIntoNewCommit)
2022-01-31 22:11:34 +11:00
err := gui.git.Patch.PullPatchIntoNewCommit(gui.State.Model.Commits, commitIndex)
2022-02-06 15:54:26 +11:00
return gui.helpers.MergeAndRebase.CheckMergeOrRebase(err)
})
}
2020-03-30 08:49:20 +11:00
func (gui *Gui) handleApplyPatch(reverse bool) error {
2020-03-26 21:00:08 +11:00
if err := gui.returnFocusFromLineByLinePanelIfNecessary(); err != nil {
return err
}
action := gui.c.Tr.Actions.ApplyPatch
if reverse {
2022-01-05 12:01:59 +11:00
action = "Apply patch in reverse"
}
gui.c.LogAction(action)
if err := gui.git.Patch.PatchManager.ApplyPatches(reverse); err != nil {
return gui.c.Error(err)
2020-03-26 21:00:08 +11:00
}
return gui.c.Refresh(types.RefreshOptions{Mode: types.ASYNC})
2020-03-26 21:00:08 +11:00
}
2019-11-05 18:10:47 +11:00
func (gui *Gui) handleResetPatch() error {
gui.git.Patch.PatchManager.Reset()
2022-01-29 19:15:46 +11:00
if gui.currentContextKeyIgnoringPopups() == context.MAIN_PATCH_BUILDING_CONTEXT_KEY {
if err := gui.c.PushContext(gui.State.Contexts.CommitFiles); err != nil {
2020-08-23 11:23:32 +10:00
return err
}
}
if err := gui.handleEscapePatchBuildingPanel(); err != nil {
return err
}
return gui.refreshCommitFilesContext()
}