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