1
0
mirror of https://github.com/jesseduffield/lazygit.git synced 2025-01-24 05:36:19 +02:00
lazygit/pkg/gui/patch_building_panel.go

134 lines
3.5 KiB
Go
Raw Normal View History

package gui
import (
"github.com/jesseduffield/lazygit/pkg/utils"
)
// getFromAndReverseArgsForDiff tells us the from and reverse args to be used in a diff command. If we're not in diff mode we'll end up with the equivalent of a `git show` i.e `git diff blah^..blah`.
func (gui *Gui) getFromAndReverseArgsForDiff(to string) (string, bool) {
from := to + "^"
reverse := false
if gui.State.Modes.Diffing.Active() {
reverse = gui.State.Modes.Diffing.Reverse
from = gui.State.Modes.Diffing.Ref
}
return from, reverse
}
2021-04-18 16:30:34 +10:00
func (gui *Gui) refreshPatchBuildingPanel(selectedLineIdx int, state *LblPanelState) error {
2022-01-02 10:34:33 +11:00
if !gui.GitCommand.Patch.PatchManager.Active() {
2020-08-15 17:23:16 +10:00
return gui.handleEscapePatchBuildingPanel()
}
2021-04-04 23:51:59 +10:00
gui.Views.Main.Title = "Patch"
gui.Views.Secondary.Title = "Custom Patch"
2019-11-10 16:20:35 +11:00
// get diff from commit file that's currently selected
2021-03-31 22:08:55 +11:00
node := gui.getSelectedCommitFileNode()
if node == nil {
2020-03-09 11:34:10 +11:00
return nil
}
to := gui.State.CommitFileManager.GetParent()
from, reverse := gui.getFromAndReverseArgsForDiff(to)
2022-01-02 10:34:33 +11:00
diff, err := gui.GitCommand.WorkingTree.ShowFileDiff(from, to, reverse, node.GetPath(), true)
if err != nil {
return err
}
2022-01-02 10:34:33 +11:00
secondaryDiff := gui.GitCommand.Patch.PatchManager.RenderPatchForFile(node.GetPath(), true, false, true)
if err != nil {
return err
}
2021-04-18 16:30:34 +10:00
empty, err := gui.refreshLineByLinePanel(diff, secondaryDiff, false, selectedLineIdx)
if err != nil {
return err
}
if empty {
2020-08-15 17:23:16 +10:00
return gui.handleEscapePatchBuildingPanel()
}
return nil
}
2020-10-08 08:01:04 +11:00
func (gui *Gui) handleRefreshPatchBuildingPanel(selectedLineIdx int) error {
gui.Mutexes.LineByLinePanelMutex.Lock()
defer gui.Mutexes.LineByLinePanelMutex.Unlock()
return gui.refreshPatchBuildingPanel(selectedLineIdx, gui.State.Panels.LineByLine)
}
2020-10-07 17:54:45 +11:00
func (gui *Gui) handleToggleSelectionForPatch() error {
2021-04-18 16:30:34 +10:00
err := gui.withLBLActiveCheck(func(state *LblPanelState) error {
2022-01-02 10:34:33 +11:00
toggleFunc := gui.GitCommand.Patch.PatchManager.AddFileLineRange
2020-10-07 17:54:45 +11:00
filename := gui.getSelectedCommitFileName()
2022-01-02 10:34:33 +11:00
includedLineIndices, err := gui.GitCommand.Patch.PatchManager.GetFileIncLineIndices(filename)
2020-10-07 17:54:45 +11:00
if err != nil {
return err
}
2021-04-18 16:30:34 +10:00
currentLineIsStaged := utils.IncludesInt(includedLineIndices, state.GetSelectedLineIdx())
2020-10-07 17:54:45 +11:00
if currentLineIsStaged {
2022-01-02 10:34:33 +11:00
toggleFunc = gui.GitCommand.Patch.PatchManager.RemoveFileLineRange
2020-10-07 17:54:45 +11:00
}
2020-10-07 17:54:45 +11:00
// add range of lines to those set for the file
2021-03-31 22:08:55 +11:00
node := gui.getSelectedCommitFileNode()
if node == nil {
2020-10-07 17:54:45 +11:00
return nil
}
2021-04-18 16:30:34 +10:00
firstLineIdx, lastLineIdx := state.SelectedRange()
if err := toggleFunc(node.GetPath(), firstLineIdx, lastLineIdx); err != nil {
2020-10-07 17:54:45 +11:00
// might actually want to return an error here
gui.Log.Error(err)
}
2020-10-07 17:54:45 +11:00
return nil
})
2020-10-08 08:01:04 +11:00
if err != nil {
return err
}
if err := gui.refreshCommitFilesView(); err != nil {
return err
}
return nil
}
2020-08-15 17:23:16 +10:00
func (gui *Gui) handleEscapePatchBuildingPanel() error {
gui.escapeLineByLinePanel()
2022-01-02 10:34:33 +11:00
if gui.GitCommand.Patch.PatchManager.IsEmpty() {
gui.GitCommand.Patch.PatchManager.Reset()
}
2021-04-03 15:56:11 +11:00
if gui.currentContext().GetKey() == gui.State.Contexts.PatchBuilding.GetKey() {
return gui.pushContext(gui.State.Contexts.CommitFiles)
} else {
// need to re-focus in case the secondary view should now be hidden
return gui.currentContext().HandleFocus()
}
}
2019-11-05 15:11:35 +11:00
2020-08-18 22:02:35 +10:00
func (gui *Gui) secondaryPatchPanelUpdateOpts() *viewUpdateOpts {
2022-01-02 10:34:33 +11:00
if gui.GitCommand.Patch.PatchManager.Active() {
patch := gui.GitCommand.Patch.PatchManager.RenderAggregatedPatchColored(false)
2020-08-18 22:02:35 +10:00
return &viewUpdateOpts{
title: "Custom Patch",
noWrap: true,
highlight: true,
2021-04-04 23:51:59 +10:00
task: NewRenderStringWithoutScrollTask(patch),
2020-08-18 22:02:35 +10:00
}
}
return nil
}