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

162 lines
4.1 KiB
Go
Raw Normal View History

package gui
import (
"fmt"
"strings"
2021-06-05 15:08:36 +10:00
2022-01-29 19:15:46 +11:00
"github.com/jesseduffield/lazygit/pkg/gui/context"
2021-06-05 15:08:36 +10:00
"github.com/jesseduffield/lazygit/pkg/gui/modes/diffing"
2022-01-28 20:44:36 +11:00
"github.com/jesseduffield/lazygit/pkg/gui/types"
)
func (gui *Gui) exitDiffMode() error {
2021-06-05 15:08:36 +10:00
gui.State.Modes.Diffing = diffing.New()
return gui.c.Refresh(types.RefreshOptions{Mode: types.ASYNC})
}
func (gui *Gui) renderDiff() error {
2022-02-06 13:42:17 +11:00
cmdObj := gui.os.Cmd.New(
2020-09-28 08:21:53 +10:00
fmt.Sprintf("git diff --submodule --no-ext-diff --color %s", gui.diffStr()),
2020-08-18 22:02:35 +10:00
)
2021-12-07 21:59:36 +11:00
task := NewRunPtyTask(cmdObj.GetCmd())
2020-08-18 22:02:35 +10:00
2020-08-23 09:46:28 +10:00
return gui.refreshMainViews(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 {
2022-02-13 12:47:15 +11:00
c := gui.currentSideContext()
if c.GetKey() == "" {
2020-08-22 11:05:37 +10:00
return nil
2022-02-13 12:47:15 +11:00
}
switch v := c.(type) {
case *context.WorkingTreeContext, *context.SubmodulesContext:
2020-09-30 08:27:23 +10:00
// TODO: should we just return nil here?
return []string{""}
2022-02-13 12:47:15 +11:00
case *context.CommitFilesContext:
2022-03-26 22:18:08 +09:00
return []string{v.GetRef().RefName()}
2022-02-13 12:47:15 +11:00
case *context.BranchesContext:
2020-08-22 11:05:37 +10:00
// for our local branches we want to include both the branch and its upstream
2022-02-05 17:04:10 +11:00
branch := gui.State.Contexts.Branches.GetSelected()
2020-08-19 22:57:22 +10:00
if branch != nil {
2020-08-22 11:05:37 +10:00
names := []string{branch.ID()}
if branch.IsTrackingRemote() {
names = append(names, branch.ID()+"@{u}")
}
2020-08-19 22:57:22 +10:00
return names
}
return nil
2022-02-13 12:47:15 +11:00
case types.IListContext:
itemId := v.GetSelectedItemId()
2022-01-30 20:03:08 +11:00
return []string{itemId}
}
2022-02-13 12:47:15 +11: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) currentlySelectedFilename() string {
switch gui.currentContext().GetKey() {
2022-01-29 19:15:46 +11:00
case context.FILES_CONTEXT_KEY, context.COMMIT_FILES_CONTEXT_KEY:
return gui.getSideContextSelectedItemId()
default:
return ""
}
}
func (gui *Gui) diffStr() string {
2020-08-22 11:05:37 +10:00
output := gui.State.Modes.Diffing.Ref
2020-03-29 17:54:58 +11:00
right := gui.currentDiffTerminal()
2020-03-29 17:54:58 +11:00
if right != "" {
output += " " + right
}
2020-08-22 11:05:37 +10:00
if gui.State.Modes.Diffing.Reverse {
2020-03-29 17:54:58 +11:00
output += " -R"
}
file := gui.currentlySelectedFilename()
if file != "" {
output += " -- " + file
} else if gui.State.Modes.Filtering.Active() {
2021-04-03 11:32:14 +11:00
output += " -- " + gui.State.Modes.Filtering.GetPath()
}
2020-03-29 17:54:58 +11:00
return output
}
func (gui *Gui) handleCreateDiffingMenuPanel() error {
names := gui.currentDiffTerminals()
2022-01-29 19:09:20 +11:00
menuItems := []*types.MenuItem{}
for _, name := range names {
name := name
2022-01-29 19:09:20 +11:00
menuItems = append(menuItems, []*types.MenuItem{
{
Label: fmt.Sprintf("%s %s", gui.c.Tr.LcDiff, name),
2022-01-28 20:44:36 +11:00
OnPress: func() error {
2020-08-22 11:05:37 +10:00
gui.State.Modes.Diffing.Ref = name
// can scope this down based on current view but too lazy right now
return gui.c.Refresh(types.RefreshOptions{Mode: types.ASYNC})
},
},
}...)
}
2022-01-29 19:09:20 +11:00
menuItems = append(menuItems, []*types.MenuItem{
{
Label: gui.c.Tr.LcEnterRefToDiff,
2022-01-28 20:44:36 +11:00
OnPress: func() error {
2022-01-29 19:09:20 +11:00
return gui.c.Prompt(types.PromptOpts{
Title: gui.c.Tr.LcEnteRefName,
2022-01-31 22:11:34 +11:00
FindSuggestionsFunc: gui.helpers.Suggestions.GetRefsSuggestionsFunc(),
2022-01-28 20:44:36 +11:00
HandleConfirm: func(response string) error {
2020-11-28 13:35:58 +11:00
gui.State.Modes.Diffing.Ref = strings.TrimSpace(response)
return gui.c.Refresh(types.RefreshOptions{Mode: types.ASYNC})
2020-11-28 13:35:58 +11:00
},
})
},
},
}...)
if gui.State.Modes.Diffing.Active() {
2022-01-29 19:09:20 +11:00
menuItems = append(menuItems, []*types.MenuItem{
2020-03-29 17:54:58 +11:00
{
Label: gui.c.Tr.LcSwapDiff,
2022-01-28 20:44:36 +11:00
OnPress: func() error {
2020-08-22 11:05:37 +10:00
gui.State.Modes.Diffing.Reverse = !gui.State.Modes.Diffing.Reverse
return gui.c.Refresh(types.RefreshOptions{Mode: types.ASYNC})
2020-03-29 17:54:58 +11:00
},
},
{
Label: gui.c.Tr.LcExitDiffMode,
2022-01-28 20:44:36 +11:00
OnPress: func() error {
2021-06-05 15:08:36 +10:00
gui.State.Modes.Diffing = diffing.New()
return gui.c.Refresh(types.RefreshOptions{Mode: types.ASYNC})
2020-03-29 17:54:58 +11:00
},
},
2020-03-29 17:54:58 +11:00
}...)
}
2022-01-29 19:09:20 +11:00
return gui.c.Menu(types.CreateMenuOptions{Title: gui.c.Tr.DiffingMenuTitle, Items: menuItems})
}