1
0
mirror of https://github.com/jesseduffield/lazygit.git synced 2025-01-10 04:07:18 +02:00
lazygit/pkg/gui/status_tree.go

64 lines
1.4 KiB
Go
Raw Normal View History

package gui
import (
"os"
2021-03-14 05:41:11 +02:00
"path/filepath"
2021-03-21 00:57:13 +02:00
"sort"
"strings"
"github.com/jesseduffield/lazygit/pkg/commands/models"
)
2021-03-21 01:46:43 +02:00
func GetTreeFromStatusFiles(files []*models.File) *models.FileChangeNode {
2021-03-21 01:23:14 +02:00
root := &models.FileChangeNode{}
2021-03-21 01:23:14 +02:00
var curr *models.FileChangeNode
for _, file := range files {
split := strings.Split(file.Name, string(os.PathSeparator))
curr = root
outer:
2021-03-20 23:41:06 +02:00
for i := range split {
var setFile *models.File
2021-03-20 23:41:06 +02:00
isFile := i == len(split)-1
if isFile {
setFile = file
}
2021-03-20 23:41:06 +02:00
path := filepath.Join(split[:i+1]...)
for _, existingChild := range curr.Children {
2021-03-20 23:41:06 +02:00
if existingChild.Path == path {
curr = existingChild
continue outer
}
}
2021-03-20 23:41:06 +02:00
2021-03-21 01:23:14 +02:00
newChild := &models.FileChangeNode{
2021-03-20 23:41:06 +02:00
Path: path,
File: setFile,
}
curr.Children = append(curr.Children, newChild)
curr = newChild
}
}
root.Sort()
root.Compress()
return root
}
2021-03-20 23:41:06 +02:00
2021-03-21 01:23:14 +02:00
func GetFlatTreeFromStatusFiles(files []*models.File) *models.FileChangeNode {
2021-03-21 01:46:43 +02:00
rootAux := GetTreeFromStatusFiles(files)
sortedFiles := rootAux.GetLeaves()
2021-03-21 00:06:15 +02:00
2021-03-21 00:57:13 +02:00
// Move merge conflicts to top. This is the one way in which sorting
// differs between flat mode and tree mode
2021-03-21 01:46:43 +02:00
sort.SliceStable(sortedFiles, func(i, j int) bool {
return sortedFiles[i].File != nil && sortedFiles[i].File.HasMergeConflicts && !(sortedFiles[j].File != nil && sortedFiles[j].File.HasMergeConflicts)
2021-03-21 00:57:13 +02:00
})
2021-03-21 01:46:43 +02:00
return &models.FileChangeNode{Children: sortedFiles}
2021-03-20 23:41:06 +02:00
}