1
0
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:
Jesse Duffield 2021-03-20 13:49:43 +11:00
parent cd0532b4d6
commit c27cea6f30
4 changed files with 29 additions and 47 deletions

View File

@ -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 {

View File

@ -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

View File

@ -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)

View File

@ -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() {