1
0
mirror of https://github.com/jesseduffield/lazygit.git synced 2025-03-03 15:02:52 +02:00
lazygit/pkg/gui/controllers/helpers/working_tree_helper.go

75 lines
1.7 KiB
Go
Raw Normal View History

2022-02-06 15:54:26 +11:00
package helpers
import (
2022-03-26 15:52:35 +11:00
"github.com/jesseduffield/lazygit/pkg/commands"
"github.com/jesseduffield/lazygit/pkg/commands/models"
2022-01-31 22:11:34 +11:00
"github.com/jesseduffield/lazygit/pkg/gui/types"
)
2022-01-31 22:11:34 +11:00
type IWorkingTreeHelper interface {
AnyStagedFiles() bool
AnyTrackedFiles() bool
IsWorkingTreeDirty() bool
FileForSubmodule(submodule *models.SubmoduleConfig) *models.File
}
type WorkingTreeHelper struct {
2022-03-26 15:52:35 +11:00
c *types.HelperCommon
git *commands.GitCommand
2022-01-31 22:11:34 +11:00
model *types.Model
}
2022-03-26 15:52:35 +11:00
func NewWorkingTreeHelper(c *types.HelperCommon, git *commands.GitCommand, model *types.Model) *WorkingTreeHelper {
return &WorkingTreeHelper{
2022-03-26 15:52:35 +11:00
c: c,
git: git,
2022-01-31 22:11:34 +11:00
model: model,
}
}
func (self *WorkingTreeHelper) AnyStagedFiles() bool {
2022-01-31 22:11:34 +11:00
for _, file := range self.model.Files {
if file.HasStagedChanges {
return true
}
}
return false
}
func (self *WorkingTreeHelper) AnyTrackedFiles() bool {
2022-01-31 22:11:34 +11:00
for _, file := range self.model.Files {
if file.Tracked {
return true
}
}
return false
}
func (self *WorkingTreeHelper) IsWorkingTreeDirty() bool {
return self.AnyStagedFiles() || self.AnyTrackedFiles()
}
func (self *WorkingTreeHelper) FileForSubmodule(submodule *models.SubmoduleConfig) *models.File {
2022-01-31 22:11:34 +11:00
for _, file := range self.model.Files {
if file.IsSubmodule([]*models.SubmoduleConfig{submodule}) {
return file
}
}
return nil
}
2022-03-26 15:52:35 +11:00
func (self *WorkingTreeHelper) OpenMergeTool() error {
return self.c.Ask(types.AskOpts{
Title: self.c.Tr.MergeToolTitle,
Prompt: self.c.Tr.MergeToolPrompt,
HandleConfirm: func() error {
self.c.LogAction(self.c.Tr.Actions.OpenMergeTool)
return self.c.RunSubprocessAndRefresh(
self.git.WorkingTree.OpenMergeToolCmdObj(),
)
},
})
}