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

108 lines
3.2 KiB
Go
Raw Normal View History

2020-09-29 11:22:26 +02:00
package commands
import (
"fmt"
"strings"
"github.com/jesseduffield/lazygit/pkg/commands/models"
2020-09-29 11:22:26 +02:00
"github.com/jesseduffield/lazygit/pkg/utils"
)
2021-03-20 23:41:06 +02:00
const RENAME_SEPARATOR = " -> "
2020-09-29 12:03:39 +02:00
// GetStatusFiles git status files
type GetStatusFileOptions struct {
NoRenames bool
}
2020-09-29 11:22:26 +02:00
func (c *GitCommand) GetStatusFiles(opts GetStatusFileOptions) []*models.File {
// check if config wants us ignoring untracked files
untrackedFilesSetting := c.GetConfigValue("status.showUntrackedFiles")
if untrackedFilesSetting == "" {
untrackedFilesSetting = "all"
}
untrackedFilesArg := fmt.Sprintf("--untracked-files=%s", untrackedFilesSetting)
statusStrings, err := c.GitStatus(GitStatusOptions{NoRenames: opts.NoRenames, UntrackedFilesArg: untrackedFilesArg})
2020-09-29 11:22:26 +02:00
if err != nil {
c.Log.Error(err)
}
files := []*models.File{}
for _, statusString := range statusStrings {
if strings.HasPrefix(statusString, "warning") {
c.Log.Warningf("warning when calling git status: %s", statusString)
continue
}
change := statusString[0:2]
stagedChange := change[0:1]
unstagedChange := statusString[1:2]
2021-03-20 23:41:06 +02:00
name := statusString[3:]
2020-09-29 11:22:26 +02:00
untracked := utils.IncludesString([]string{"??", "A ", "AM"}, change)
hasNoStagedChanges := utils.IncludesString([]string{" ", "U", "?"}, stagedChange)
hasMergeConflicts := utils.IncludesString([]string{"DD", "AA", "UU", "AU", "UA", "UD", "DU"}, change)
hasInlineMergeConflicts := utils.IncludesString([]string{"UU", "AA"}, change)
2021-03-20 23:41:06 +02:00
previousName := ""
if strings.Contains(name, RENAME_SEPARATOR) {
split := strings.Split(name, RENAME_SEPARATOR)
name = split[1]
previousName = split[0]
}
2020-09-29 11:22:26 +02:00
file := &models.File{
2021-03-20 23:41:06 +02:00
Name: name,
PreviousName: previousName,
2020-09-29 11:22:26 +02:00
DisplayString: statusString,
HasStagedChanges: !hasNoStagedChanges,
HasUnstagedChanges: unstagedChange != " ",
Tracked: !untracked,
Deleted: unstagedChange == "D" || stagedChange == "D",
2021-03-20 03:07:11 +02:00
Added: unstagedChange == "A" || untracked,
2020-09-29 11:22:26 +02:00
HasMergeConflicts: hasMergeConflicts,
HasInlineMergeConflicts: hasInlineMergeConflicts,
2021-03-20 23:41:06 +02:00
Type: c.OSCommand.FileType(name),
2020-09-29 11:22:26 +02:00
ShortStatus: change,
}
files = append(files, file)
}
2020-09-29 11:22:26 +02:00
return files
}
// GitStatus returns the plaintext short status of the repo
type GitStatusOptions struct {
NoRenames bool
UntrackedFilesArg string
}
func (c *GitCommand) GitStatus(opts GitStatusOptions) ([]string, error) {
2020-09-29 11:22:26 +02:00
noRenamesFlag := ""
if opts.NoRenames {
noRenamesFlag = "--no-renames"
}
statusLines, err := c.RunCommandWithOutput("git status %s --porcelain -z %s", opts.UntrackedFilesArg, noRenamesFlag)
if err != nil {
return []string{}, err
}
2021-03-14 04:20:54 +02:00
splitLines := strings.Split(statusLines, "\x00")
response := []string{}
for i := 0; i < len(splitLines); i++ {
2021-03-14 04:20:54 +02:00
original := splitLines[i]
if len(original) < 2 {
continue
} else if strings.HasPrefix(original, "R ") {
// if a line starts with 'R' then the next line is the original file.
next := strings.TrimSpace(splitLines[i+1])
original = "R " + next + RENAME_SEPARATOR + strings.TrimPrefix(original, "R ")
i++
2021-03-14 04:20:54 +02:00
}
response = append(response, original)
2021-03-14 04:20:54 +02:00
}
return response, nil
2020-09-29 11:22:26 +02:00
}