summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--modules/git/command.go2
-rw-r--r--modules/git/git.go11
2 files changed, 12 insertions, 1 deletions
diff --git a/modules/git/command.go b/modules/git/command.go
index d354635119..3602717702 100644
--- a/modules/git/command.go
+++ b/modules/git/command.go
@@ -41,7 +41,7 @@ func NewCommand(args ...string) *Command {
cargs := make([]string, len(GlobalCommandArgs))
copy(cargs, GlobalCommandArgs)
return &Command{
- name: "git",
+ name: GitExecutable,
args: append(cargs, args...),
}
}
diff --git a/modules/git/git.go b/modules/git/git.go
index 150b80fb07..abae0423c2 100644
--- a/modules/git/git.go
+++ b/modules/git/git.go
@@ -7,6 +7,7 @@ package git
import (
"fmt"
+ "os/exec"
"strings"
"time"
@@ -26,6 +27,10 @@ var (
Prefix = "[git-module] "
// GitVersionRequired is the minimum Git version required
GitVersionRequired = "1.7.2"
+
+ // GitExecutable is the command name of git
+ // Could be updated to an absolute path while initialization
+ GitExecutable = "git"
)
func log(format string, args ...interface{}) {
@@ -71,6 +76,12 @@ func BinVersion() (string, error) {
}
func init() {
+ absPath, err := exec.LookPath(GitExecutable)
+ if err != nil {
+ panic(fmt.Sprintf("Git not found: %v", err))
+ }
+ GitExecutable = absPath
+
gitVersion, err := BinVersion()
if err != nil {
panic(fmt.Sprintf("Git version missing: %v", err))