mirror of
https://github.com/goreleaser/goreleaser.git
synced 2025-03-23 21:19:17 +02:00
Improved the error handling in git code, mostly in the defaults pipe. The idea is to output better error messages, hopefully avoiding confusion on "whats wrong". refs #356
44 lines
945 B
Go
44 lines
945 B
Go
package defaults
|
|
|
|
import (
|
|
"os"
|
|
"os/exec"
|
|
"strings"
|
|
|
|
"github.com/goreleaser/goreleaser/config"
|
|
"github.com/pkg/errors"
|
|
)
|
|
|
|
// remoteRepo gets the repo name from the Git config.
|
|
func remoteRepo() (result config.Repo, err error) {
|
|
if _, err = os.Stat(".git"); os.IsNotExist(err) {
|
|
return result, errors.Wrap(err, "current folder is not a git repository")
|
|
}
|
|
cmd := exec.Command("git", "config", "--get", "remote.origin.url")
|
|
bts, err := cmd.CombinedOutput()
|
|
if err != nil {
|
|
return result, errors.Wrap(err, "repository doesn't have an `origin` remote")
|
|
}
|
|
return extractRepoFromURL(string(bts)), nil
|
|
}
|
|
|
|
func extractRepoFromURL(s string) config.Repo {
|
|
for _, r := range []string{
|
|
"git@github.com:",
|
|
".git",
|
|
"https://github.com/",
|
|
"\n",
|
|
} {
|
|
s = strings.Replace(s, r, "", -1)
|
|
}
|
|
return toRepo(s)
|
|
}
|
|
|
|
func toRepo(s string) config.Repo {
|
|
var ss = strings.Split(s, "/")
|
|
return config.Repo{
|
|
Owner: ss[0],
|
|
Name: ss[1],
|
|
}
|
|
}
|