Improve Git config

This commit is contained in:
Thomas Miceli 2024-11-23 17:25:58 +01:00
parent 5994cd6ccd
commit 8f482bce33

View file

@ -1,15 +1,24 @@
package git package git
import "os/exec" import (
"errors"
"os/exec"
"regexp"
)
func InitGitConfig() error { type configEntry struct {
configs := map[string]string{ value string
"receive.advertisePushOptions": "true", fn func(string, string) error
"safe.directory": "*",
} }
for key, value := range configs { func InitGitConfig() error {
if err := setGitConfig(key, value); err != nil { configs := map[string]configEntry{
"receive.advertisePushOptions": {value: "true", fn: setGitConfig},
"safe.directory": {value: "*", fn: addGitConfig},
}
for key, entry := range configs {
if err := entry.fn(key, entry.value); err != nil {
return err return err
} }
} }
@ -18,6 +27,37 @@ func InitGitConfig() error {
} }
func setGitConfig(key, value string) error { func setGitConfig(key, value string) error {
_, err := getGitConfig(key, value)
if err != nil && !checkErrorCode(err, 1) {
return err
}
cmd := exec.Command("git", "config", "--global", key, value) cmd := exec.Command("git", "config", "--global", key, value)
return cmd.Run() return cmd.Run()
} }
func addGitConfig(key, value string) error {
_, err := getGitConfig(key, regexp.QuoteMeta(value))
if err == nil {
return nil
}
if checkErrorCode(err, 1) {
cmd := exec.Command("git", "config", "--global", "--add", key, value)
return cmd.Run()
}
return err
}
func getGitConfig(key, value string) (string, error) {
cmd := exec.Command("git", "config", "--global", "--get", key, value)
out, err := cmd.Output()
return string(out), err
}
func checkErrorCode(err error, code int) bool {
var exitError *exec.ExitError
if errors.As(err, &exitError) {
return exitError.ExitCode() == code
}
return false
}