Make depth configurable per path
This commit is contained in:
parent
f91b6e4cbd
commit
6644029a77
2 changed files with 22 additions and 3 deletions
|
@ -4,21 +4,26 @@ import (
|
|||
"fmt"
|
||||
"log"
|
||||
"os/exec"
|
||||
"strings"
|
||||
|
||||
"git-repo-updater/internal/utils"
|
||||
)
|
||||
|
||||
func FindInDirectory(dir string) (string, error) {
|
||||
expanded, err := utils.ExpandPath(dir)
|
||||
repoPath, err := utils.ExpandPath(dir)
|
||||
|
||||
if err != nil {
|
||||
log.Fatal(err)
|
||||
}
|
||||
|
||||
cmd := exec.Command("find", expanded, "-type", "d", "-name", ".git", "-mindepth", "1", "-maxdepth", "2")
|
||||
repoPath, depth := splitPath(repoPath)
|
||||
|
||||
cmd := exec.Command("find", repoPath, "-type", "d", "-name", ".git", "-mindepth", "1", "-maxdepth", depth)
|
||||
|
||||
output, err := cmd.CombinedOutput()
|
||||
|
||||
fmt.Println(string(output))
|
||||
|
||||
if err != nil {
|
||||
if exitErr, ok := err.(*exec.ExitError); ok {
|
||||
exitCode := exitErr.ExitCode()
|
||||
|
@ -31,3 +36,16 @@ func FindInDirectory(dir string) (string, error) {
|
|||
|
||||
return string(output), nil
|
||||
}
|
||||
|
||||
func splitPath(repoPath string) (string, string) {
|
||||
parts := strings.SplitN(repoPath, ":", 2)
|
||||
|
||||
repoPath = parts[0]
|
||||
depth := "2"
|
||||
|
||||
if len(parts) == 2 {
|
||||
return parts[0], parts[1]
|
||||
}
|
||||
|
||||
return repoPath, depth
|
||||
}
|
||||
|
|
3
todo.txt
3
todo.txt
|
@ -1,4 +1,5 @@
|
|||
* Load directories from a configuration file
|
||||
* Update the repositories within each directory.
|
||||
* Make depth configurable per directory.
|
||||
|
||||
Make depth configurable per directory.
|
||||
Set a default depth in config.yaml.
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue