1
0
mirror of https://github.com/jesseduffield/lazygit.git synced 2025-04-18 06:24:01 +03:00

Escape special characters when git-ignoring files

This commit is contained in:
Stefan Haller 2025-04-09 13:27:44 +02:00 committed by Jesse Duffield
parent 41f89d86f0
commit b0ab6529c1
2 changed files with 9 additions and 23 deletions

View File

@ -4,6 +4,7 @@ import (
"fmt"
"os"
"path/filepath"
"regexp"
"github.com/go-errors/errors"
"github.com/jesseduffield/lazygit/pkg/commands/models"
@ -230,15 +231,21 @@ func (self *WorkingTreeCommands) DiscardUnstagedFileChanges(file *models.File) e
return self.cmd.New(cmdArgs).Run()
}
// Escapes special characters in a filename for gitignore and exclude files
func escapeFilename(filename string) string {
re := regexp.MustCompile(`^[!#]|[\[\]*]`)
return re.ReplaceAllString(filename, `\${0}`)
}
// Ignore adds a file to the gitignore for the repo
func (self *WorkingTreeCommands) Ignore(filename string) error {
return self.os.AppendLineToFile(".gitignore", filename)
return self.os.AppendLineToFile(".gitignore", escapeFilename(filename))
}
// Exclude adds a file to the .git/info/exclude for the repo
func (self *WorkingTreeCommands) Exclude(filename string) error {
excludeFile := filepath.Join(self.repoPaths.repoGitDirPath, "info", "exclude")
return self.os.AppendLineToFile(excludeFile, filename)
return self.os.AppendLineToFile(excludeFile, escapeFilename(filename))
}
// WorktreeFileDiff returns the diff of a file

View File

@ -55,33 +55,12 @@ var GitignoreSpecialCharacters = NewIntegrationTest(NewIntegrationTestArgs{
excludeFile("file[x]")
t.Views().Files().
/* EXPECTED:
Lines(
Equals("▼ /"),
Equals(" ?? .gitignore"),
Equals(" ?? abc_def"),
)
ACTUAL:
As you can see, it did ignore the 'file!abc' and 'file#abc' files
correctly. Those don't need to be quoted because # and ! are only
special at the beginning.
Most of the other files are not ignored properly because their
special characters need to be escaped. For * it's the other way
round: while it does hide 'abc*def', it also hides 'abc_def',
which we don't want.
*/
Lines(
Equals("▼ /"),
Equals(" ?? !file"),
Equals(" ?? #file"),
Equals(" ?? .gitignore"),
Equals(" ?? file[x]"),
)
/* EXPECTED:
t.FileSystem().FileContent(".gitignore", Equals("\\#file\nfile#abc\n\\!file\nfile!abc\nabc\\*def\nfile\\[x\\]\n"))
ACTUAL: */
t.FileSystem().FileContent(".gitignore", Equals("#file\nfile#abc\n!file\nfile!abc\nabc*def\nfile[x]\n"))
},
})