1
0
mirror of https://github.com/jesseduffield/lazygit.git synced 2025-01-08 04:04:22 +02:00

Merge pull request #279 from jesseduffield/hotfix/file-ordering

Restore old file merging algorithm
This commit is contained in:
Jesse Duffield 2018-09-12 18:26:29 +10:00 committed by GitHub
commit 79940b7ba9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -173,28 +173,37 @@ func (c *GitCommand) MergeStatusFiles(oldFiles, newFiles []File) []File {
return newFiles
}
headResults := []File{}
tailResults := []File{}
appendedIndexes := []int{}
for _, newFile := range newFiles {
var isHeadResult bool
for _, oldFile := range oldFiles {
// retain position of files we already could see
result := []File{}
for _, oldFile := range oldFiles {
for newIndex, newFile := range newFiles {
if oldFile.Name == newFile.Name {
isHeadResult = true
result = append(result, newFile)
appendedIndexes = append(appendedIndexes, newIndex)
break
}
}
if isHeadResult {
headResults = append(headResults, newFile)
continue
}
tailResults = append(tailResults, newFile)
}
return append(headResults, tailResults...)
// append any new files to the end
for index, newFile := range newFiles {
if !includesInt(appendedIndexes, index) {
result = append(result, newFile)
}
}
return result
}
func includesInt(list []int, a int) bool {
for _, b := range list {
if b == a {
return true
}
}
return false
}
// GetBranchName branch name