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

171 lines
4.0 KiB
Go
Raw Normal View History

package gui
import (
"fmt"
"strings"
"github.com/jesseduffield/gocui"
)
func (gui *Gui) inDiffMode() bool {
return gui.State.Diff.Ref != ""
}
func (gui *Gui) exitDiffMode() error {
gui.State.Diff = DiffState{}
return gui.refreshSidePanels(refreshOptions{mode: ASYNC})
}
func (gui *Gui) renderDiff() error {
2020-08-18 22:02:35 +10:00
filterArg := ""
if gui.inFilterMode() {
filterArg = fmt.Sprintf(" -- %s", gui.State.FilterPath)
}
cmd := gui.OSCommand.ExecutableFromString(
fmt.Sprintf("git diff --color %s %s", gui.diffStr(), filterArg),
)
task := gui.createRunPtyTask(cmd)
return gui.refreshMain(refreshMainOpts{
main: &viewUpdateOpts{
title: "Diff",
2020-08-18 22:02:35 +10:00
task: task,
},
})
}
// currentDiffTerminals returns the current diff terminals of the currently selected item.
// in the case of a branch it returns both the branch and it's upstream name,
// which becomes an option when you bring up the diff menu, but when you're just
// flicking through branches it will be using the local branch name.
func (gui *Gui) currentDiffTerminals() []string {
2020-08-19 22:57:22 +10:00
switch gui.currentContextKey() {
2020-08-20 19:42:58 +10:00
case FILES_CONTEXT_KEY:
2020-08-16 17:45:12 +10:00
// not supporting files for now
2020-08-20 19:42:58 +10:00
case COMMIT_FILES_CONTEXT_KEY:
// not supporting commit files for now
2020-08-20 19:42:58 +10:00
case BRANCH_COMMITS_CONTEXT_KEY:
2020-08-19 22:57:22 +10:00
item := gui.getSelectedCommit()
if item != nil {
return []string{item.RefName()}
}
2020-08-20 19:42:58 +10:00
case REFLOG_COMMITS_CONTEXT_KEY:
2020-08-19 22:57:22 +10:00
item := gui.getSelectedReflogCommit()
if item != nil {
return []string{item.RefName()}
}
2020-08-20 19:42:58 +10:00
case STASH_CONTEXT_KEY:
2020-08-19 22:57:22 +10:00
item := gui.getSelectedStashEntry()
if item != nil {
return []string{item.RefName()}
}
2020-08-19 22:57:22 +10:00
2020-08-20 19:42:58 +10:00
case LOCAL_BRANCHES_CONTEXT_KEY:
2020-08-19 22:57:22 +10:00
branch := gui.getSelectedBranch()
if branch != nil {
names := []string{branch.RefName()}
if branch.UpstreamName != "" {
names = append(names, branch.UpstreamName)
}
2020-08-19 22:57:22 +10:00
return names
}
return nil
2020-08-20 19:42:58 +10:00
case REMOTES_CONTEXT_KEY:
2020-08-19 22:57:22 +10:00
item := gui.getSelectedRemote()
if item != nil {
return []string{item.RefName()}
}
2020-08-20 19:42:58 +10:00
case REMOTE_BRANCHES_CONTEXT_KEY:
2020-08-19 22:57:22 +10:00
item := gui.getSelectedRemoteBranch()
if item != nil {
return []string{item.RefName()}
}
2020-08-20 19:42:58 +10:00
case TAGS_CONTEXT_KEY:
2020-08-19 22:57:22 +10:00
item := gui.getSelectedTag()
if item != nil {
return []string{item.RefName()}
}
}
2020-08-19 22:57:22 +10:00
return nil
}
func (gui *Gui) currentDiffTerminal() string {
names := gui.currentDiffTerminals()
if len(names) == 0 {
2020-03-29 17:54:58 +11:00
return ""
}
return names[0]
}
func (gui *Gui) diffStr() string {
2020-03-29 17:54:58 +11:00
output := gui.State.Diff.Ref
right := gui.currentDiffTerminal()
2020-03-29 17:54:58 +11:00
if right != "" {
output += " " + right
}
if gui.State.Diff.Reverse {
2020-03-29 17:54:58 +11:00
output += " -R"
}
2020-03-29 17:54:58 +11:00
return output
}
func (gui *Gui) handleCreateDiffingMenuPanel(g *gocui.Gui, v *gocui.View) error {
if gui.popupPanelFocused() {
return nil
}
names := gui.currentDiffTerminals()
menuItems := []*menuItem{}
for _, name := range names {
name := name
menuItems = append(menuItems, []*menuItem{
{
2020-03-29 17:54:58 +11:00
displayString: fmt.Sprintf("%s %s", gui.Tr.SLocalize("diff"), name),
onPress: func() error {
gui.State.Diff.Ref = name
// can scope this down based on current view but too lazy right now
return gui.refreshSidePanels(refreshOptions{mode: ASYNC})
},
},
}...)
}
menuItems = append(menuItems, []*menuItem{
{
2020-03-29 17:54:58 +11:00
displayString: gui.Tr.SLocalize("enterRefToDiff"),
onPress: func() error {
2020-08-15 16:38:16 +10:00
return gui.prompt(v, gui.Tr.SLocalize("enteRefName"), "", func(response string) error {
2020-08-15 16:36:39 +10:00
gui.State.Diff.Ref = strings.TrimSpace(response)
return gui.refreshSidePanels(refreshOptions{mode: ASYNC})
})
},
},
}...)
if gui.inDiffMode() {
2020-03-29 17:54:58 +11:00
menuItems = append(menuItems, []*menuItem{
{
displayString: gui.Tr.SLocalize("swapDiff"),
onPress: func() error {
gui.State.Diff.Reverse = !gui.State.Diff.Reverse
return gui.refreshSidePanels(refreshOptions{mode: ASYNC})
},
},
{
displayString: gui.Tr.SLocalize("exitDiffMode"),
onPress: func() error {
gui.State.Diff = DiffState{}
return gui.refreshSidePanels(refreshOptions{mode: ASYNC})
},
},
2020-03-29 17:54:58 +11:00
}...)
}
return gui.createMenu(gui.Tr.SLocalize("DiffingMenuTitle"), menuItems, createMenuOptions{showCancel: true})
}