2020-09-28 01:14:32 +02:00
|
|
|
package commands
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bufio"
|
|
|
|
"os"
|
|
|
|
"regexp"
|
2020-09-29 10:45:00 +02:00
|
|
|
|
|
|
|
"github.com/jesseduffield/lazygit/pkg/models"
|
2020-09-28 01:14:32 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
// .gitmodules looks like this:
|
|
|
|
// [submodule "mysubmodule"]
|
|
|
|
// path = blah/mysubmodule
|
|
|
|
// url = git@github.com:subbo.git
|
|
|
|
|
2020-09-29 10:45:00 +02:00
|
|
|
func (c *GitCommand) GetSubmoduleConfigs() ([]*models.SubmoduleConfig, error) {
|
2020-09-28 01:14:32 +02:00
|
|
|
file, err := os.Open(".gitmodules")
|
|
|
|
if err != nil {
|
|
|
|
if os.IsNotExist(err) {
|
|
|
|
return nil, nil
|
|
|
|
}
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
scanner := bufio.NewScanner(file)
|
|
|
|
scanner.Split(bufio.ScanLines)
|
|
|
|
|
|
|
|
firstMatch := func(str string, regex string) (string, bool) {
|
|
|
|
re := regexp.MustCompile(regex)
|
|
|
|
matches := re.FindStringSubmatch(str)
|
|
|
|
|
|
|
|
if len(matches) > 0 {
|
|
|
|
return matches[1], true
|
|
|
|
} else {
|
|
|
|
return "", false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-09-29 10:45:00 +02:00
|
|
|
configs := []*models.SubmoduleConfig{}
|
2020-09-28 01:14:32 +02:00
|
|
|
for scanner.Scan() {
|
|
|
|
line := scanner.Text()
|
|
|
|
|
|
|
|
if name, ok := firstMatch(line, `\[submodule "(.*)"\]`); ok {
|
2020-09-29 10:45:00 +02:00
|
|
|
configs = append(configs, &models.SubmoduleConfig{Name: name})
|
2020-09-28 01:14:32 +02:00
|
|
|
continue
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(configs) > 0 {
|
|
|
|
lastConfig := configs[len(configs)-1]
|
|
|
|
|
|
|
|
if path, ok := firstMatch(line, `\s*path\s*=\s*(.*)\s*`); ok {
|
|
|
|
lastConfig.Path = path
|
|
|
|
} else if url, ok := firstMatch(line, `\s*url\s*=\s*(.*)\s*`); ok {
|
|
|
|
lastConfig.Url = url
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return configs, nil
|
|
|
|
}
|
|
|
|
|
2020-09-29 10:45:00 +02:00
|
|
|
func (c *GitCommand) SubmoduleStash(config *models.SubmoduleConfig) error {
|
2020-09-29 00:47:14 +02:00
|
|
|
// if the path does not exist then it hasn't yet been initialized so we'll swallow the error
|
|
|
|
// because the intention here is to have no dirty worktree state
|
|
|
|
if _, err := os.Stat(config.Path); os.IsNotExist(err) {
|
|
|
|
c.Log.Infof("submodule path %s does not exist, returning", config.Path)
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2020-09-28 01:14:32 +02:00
|
|
|
return c.OSCommand.RunCommand("git -C %s stash --include-untracked", config.Path)
|
|
|
|
}
|
|
|
|
|
2020-09-29 10:45:00 +02:00
|
|
|
func (c *GitCommand) SubmoduleReset(config *models.SubmoduleConfig) error {
|
2020-09-28 01:14:32 +02:00
|
|
|
return c.OSCommand.RunCommand("git submodule update --force %s", config.Name)
|
|
|
|
}
|
2020-09-29 00:47:14 +02:00
|
|
|
|
|
|
|
func (c *GitCommand) SubmoduleUpdateAll() error {
|
|
|
|
return c.OSCommand.RunCommand("git submodule update --force")
|
|
|
|
}
|