mirror of
https://github.com/jesseduffield/lazygit.git
synced 2025-06-08 23:56:15 +02:00
more file tree improvements
This commit is contained in:
parent
cd0532b4d6
commit
c27cea6f30
@ -142,16 +142,8 @@ func (c *GitCommand) DiscardAllFileChanges(file *models.File) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (c *GitCommand) DiscardAllDirChanges(node *models.StatusLineNode) error {
|
func (c *GitCommand) DiscardAllDirChanges(node *models.StatusLineNode) error {
|
||||||
if err := c.RemoveUntrackedDirFiles(node); err != nil {
|
// this could be more efficient but we would need to handle all the edge cases
|
||||||
return err
|
return node.ForEachFile(c.DiscardAllFileChanges)
|
||||||
}
|
|
||||||
|
|
||||||
quotedPath := c.OSCommand.Quote(node.GetPath())
|
|
||||||
if err := c.OSCommand.RunCommand("git checkout HEAD -- %s", quotedPath); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *GitCommand) DiscardUnstagedDirChanges(node *models.StatusLineNode) error {
|
func (c *GitCommand) DiscardUnstagedDirChanges(node *models.StatusLineNode) error {
|
||||||
|
@ -13,24 +13,6 @@ type StatusLineNode struct {
|
|||||||
Collapsed bool
|
Collapsed bool
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *StatusLineNode) GetShortStatus() string {
|
|
||||||
// need to see if any child has unstaged changes.
|
|
||||||
if s.IsLeaf() {
|
|
||||||
return s.File.ShortStatus
|
|
||||||
}
|
|
||||||
|
|
||||||
firstChar := " "
|
|
||||||
secondChar := " "
|
|
||||||
if s.GetHasStagedChanges() {
|
|
||||||
firstChar = "M"
|
|
||||||
}
|
|
||||||
if s.GetHasUnstagedChanges() {
|
|
||||||
secondChar = "M"
|
|
||||||
}
|
|
||||||
|
|
||||||
return firstChar + secondChar
|
|
||||||
}
|
|
||||||
|
|
||||||
func (s *StatusLineNode) GetHasUnstagedChanges() bool {
|
func (s *StatusLineNode) GetHasUnstagedChanges() bool {
|
||||||
if s.IsLeaf() {
|
if s.IsLeaf() {
|
||||||
return s.File.HasUnstagedChanges
|
return s.File.HasUnstagedChanges
|
||||||
|
@ -19,29 +19,34 @@ func GetFileListDisplayStrings(files []*models.File, diffName string, submoduleC
|
|||||||
|
|
||||||
// getFileDisplayStrings returns the display string of branch
|
// getFileDisplayStrings returns the display string of branch
|
||||||
func getFileDisplayStrings(f *models.File, diffName string, submoduleConfigs []*models.SubmoduleConfig) []string {
|
func getFileDisplayStrings(f *models.File, diffName string, submoduleConfigs []*models.SubmoduleConfig) []string {
|
||||||
output := GetStatusNodeLine(f.HasUnstagedChanges, f.ShortStatus, f.Name, diffName, submoduleConfigs, f)
|
output := GetStatusNodeLine(f.HasUnstagedChanges, f.HasStagedChanges, f.Name, diffName, submoduleConfigs, f)
|
||||||
|
|
||||||
return []string{output}
|
return []string{output}
|
||||||
}
|
}
|
||||||
|
|
||||||
func GetStatusNodeLine(hasUnstagedChanges bool, shortStatus string, name string, diffName string, submoduleConfigs []*models.SubmoduleConfig, file *models.File) string {
|
func GetStatusNodeLine(hasUnstagedChanges bool, hasStagedChanges bool, name string, diffName string, submoduleConfigs []*models.SubmoduleConfig, file *models.File) string {
|
||||||
// potentially inefficient to be instantiating these color
|
// potentially inefficient to be instantiating these color
|
||||||
// objects with each render
|
// objects with each render
|
||||||
red := color.New(color.FgRed)
|
red := color.New(color.FgRed)
|
||||||
green := color.New(color.FgGreen)
|
green := color.New(color.FgGreen)
|
||||||
diffColor := color.New(theme.DiffTerminalColor)
|
diffColor := color.New(theme.DiffTerminalColor)
|
||||||
|
partiallyModifiedColor := color.New(color.FgYellow)
|
||||||
|
|
||||||
var restColor *color.Color
|
var restColor *color.Color
|
||||||
if name == diffName {
|
if name == diffName {
|
||||||
restColor = diffColor
|
restColor = diffColor
|
||||||
|
} else if file == nil && hasStagedChanges && hasUnstagedChanges {
|
||||||
|
restColor = partiallyModifiedColor
|
||||||
} else if hasUnstagedChanges {
|
} else if hasUnstagedChanges {
|
||||||
restColor = red
|
restColor = red
|
||||||
} else {
|
} else {
|
||||||
restColor = green
|
restColor = green
|
||||||
}
|
}
|
||||||
|
|
||||||
|
output := ""
|
||||||
|
if file != nil {
|
||||||
// this is just making things look nice when the background attribute is 'reverse'
|
// this is just making things look nice when the background attribute is 'reverse'
|
||||||
firstChar := shortStatus[0:1]
|
firstChar := file.ShortStatus[0:1]
|
||||||
firstCharCl := green
|
firstCharCl := green
|
||||||
if firstChar == "?" {
|
if firstChar == "?" {
|
||||||
firstCharCl = red
|
firstCharCl = red
|
||||||
@ -49,15 +54,18 @@ func GetStatusNodeLine(hasUnstagedChanges bool, shortStatus string, name string,
|
|||||||
firstCharCl = restColor
|
firstCharCl = restColor
|
||||||
}
|
}
|
||||||
|
|
||||||
secondChar := shortStatus[1:2]
|
secondChar := file.ShortStatus[1:2]
|
||||||
secondCharCl := red
|
secondCharCl := red
|
||||||
if secondChar == " " {
|
if secondChar == " " {
|
||||||
secondCharCl = restColor
|
secondCharCl = restColor
|
||||||
}
|
}
|
||||||
|
|
||||||
output := firstCharCl.Sprint(firstChar)
|
output = firstCharCl.Sprint(firstChar)
|
||||||
output += secondCharCl.Sprint(secondChar)
|
output += secondCharCl.Sprint(secondChar)
|
||||||
output += restColor.Sprintf(" %s", name)
|
output += " "
|
||||||
|
}
|
||||||
|
|
||||||
|
output += restColor.Sprint(name)
|
||||||
|
|
||||||
if file != nil && file.IsSubmodule(submoduleConfigs) {
|
if file != nil && file.IsSubmodule(submoduleConfigs) {
|
||||||
output += utils.ColoredString(" (submodule)", theme.DefaultTextColor)
|
output += utils.ColoredString(" (submodule)", theme.DefaultTextColor)
|
||||||
|
@ -84,7 +84,7 @@ func (m *StatusLineManager) renderAux(s *models.StatusLineNode, prefix string, d
|
|||||||
}
|
}
|
||||||
|
|
||||||
getLine := func() string {
|
getLine := func() string {
|
||||||
return prefix + presentation.GetStatusNodeLine(s.GetHasUnstagedChanges(), s.GetShortStatus(), s.Name, diffName, submoduleConfigs, s.File)
|
return prefix + presentation.GetStatusNodeLine(s.GetHasUnstagedChanges(), s.GetHasStagedChanges(), s.Name, diffName, submoduleConfigs, s.File)
|
||||||
}
|
}
|
||||||
|
|
||||||
if s.IsLeaf() {
|
if s.IsLeaf() {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user