summaryrefslogtreecommitdiff
path: root/isTracked.go
diff options
context:
space:
mode:
authorJeff Carr <[email protected]>2024-12-17 01:15:31 -0600
committerJeff Carr <[email protected]>2024-12-17 01:15:31 -0600
commit4bc95ad2684cb42159229b8198aa8a2377f80aa1 (patch)
tree57c4b95880302bfd3a34d0cc3eec6ab79f1d0993 /isTracked.go
parentc53da5a9a1da1b29db24d4e1ce2b294514d99ac2 (diff)
keep isolating use of os.Exec("git")
Diffstat (limited to 'isTracked.go')
-rw-r--r--isTracked.go72
1 files changed, 0 insertions, 72 deletions
diff --git a/isTracked.go b/isTracked.go
deleted file mode 100644
index b15db02..0000000
--- a/isTracked.go
+++ /dev/null
@@ -1,72 +0,0 @@
-package gitpb
-
-import (
- "errors"
- "fmt"
-
- "go.wit.com/log"
-)
-
-func (repo *Repo) isTracked(file string) (bool, error) {
- cmd := []string{"git", "ls-files", "--error-unmatch", file}
- result := repo.Run(cmd)
- if result.Error != nil {
- return false, result.Error
- }
- if result.Exit != 0 {
- return false, nil
- }
- return true, nil
-}
-
-func (repo *Repo) isIgnored(file string) (bool, error) {
- cmd := []string{"git", "check-ignore", "-q", file}
- result := repo.Run(cmd)
- if result.Error != nil {
- return false, result.Error
- }
- if result.Exit == 0 {
- // exit with 0 means the file is ignored
- return true, nil
- }
- // non-zero exit means the file is not ignored
- return false, nil
-}
-
-// is it a good idea to run go-mod-clean in this repo?
-// for now, check if this repo should be ignored
-// TODO: go.mod and go.sum should be moved to git tag metadata
-func (repo *Repo) RepoIgnoresGoMod() error {
- file := "go.mod"
- if tracked, err := repo.isTracked(file); err != nil {
- msg := fmt.Sprintf("%s Error checking if %s tracked: %v\n", repo.GoPath, file, err)
- log.Info("gitpb:", msg)
- return err
- } else {
- if tracked {
- msg := fmt.Sprintf("%s %s is tracked by Git.\n", repo.GoPath, file)
- log.Info("gitpb:", msg)
- return errors.New(msg)
- }
- }
-
- if ignored, err := repo.isIgnored(file); err != nil {
- if err != nil {
- msg := fmt.Sprintf("%s Error checking if ignored: %v\n", repo.GoPath, err)
- log.Info("gitpb:", msg)
- return err
- }
- } else {
- if ignored {
- fmt.Printf("%s %s is ignored by Git.\n", repo.GoPath, file)
- return nil
- }
- }
- msg := fmt.Sprintf("%s %s is neither tracked nor ignored by Git.\n", repo.GoPath, file)
- // this means, if you make a go.mod file, it'll add it to the repo to be tracked
- // so you need to either add it to .gitignore (this is what should happen)
- // or accept you want an auto-generated file to put endless garbage in your git repo
- // this obviously exposes my opinion on this subject matter
- log.Info("gitpb:", msg)
- return errors.New(msg)
-}