Commit 7207898f authored by Gustavo Niemeyer's avatar Gustavo Niemeyer

cmd/go: add support for release tags via git branches

R=rsc, remyoudompheng, gustavo, dsymonds
CC=golang-dev
https://golang.org/cl/5617057
parent b3750ff5
...@@ -24,6 +24,7 @@ type vcsCmd struct { ...@@ -24,6 +24,7 @@ type vcsCmd struct {
downloadCmd string // command to download updates into an existing repository downloadCmd string // command to download updates into an existing repository
tagCmd []tagCmd // commands to list tags tagCmd []tagCmd // commands to list tags
tagLookupCmd []tagCmd // commands to lookup tags before running tagSyncCmd
tagSyncCmd string // command to sync to specific tag tagSyncCmd string // command to sync to specific tag
tagSyncDefault string // command to sync to default tag tagSyncDefault string // command to sync to default tag
} }
...@@ -83,7 +84,14 @@ var vcsGit = &vcsCmd{ ...@@ -83,7 +84,14 @@ var vcsGit = &vcsCmd{
createCmd: "clone {repo} {dir}", createCmd: "clone {repo} {dir}",
downloadCmd: "fetch", downloadCmd: "fetch",
tagCmd: []tagCmd{{"tag", `^(\S+)$`}}, tagCmd: []tagCmd{
// tags/xxx matches a git tag named xxx
// origin/xxx matches a git branch named xxx on the default remote repository
{"show-ref", `(?:tags|origin)/(\S+)$`},
},
tagLookupCmd: []tagCmd{
{"show-ref tags/{tag} origin/{tag}", `((?:tags|origin)/\S+)$`},
},
tagSyncCmd: "checkout {tag}", tagSyncCmd: "checkout {tag}",
tagSyncDefault: "checkout origin/master", tagSyncDefault: "checkout origin/master",
} }
...@@ -128,17 +136,17 @@ func (v *vcsCmd) String() string { ...@@ -128,17 +136,17 @@ func (v *vcsCmd) String() string {
// command's combined stdout+stderr to standard error. // command's combined stdout+stderr to standard error.
// Otherwise run discards the command's output. // Otherwise run discards the command's output.
func (v *vcsCmd) run(dir string, cmd string, keyval ...string) error { func (v *vcsCmd) run(dir string, cmd string, keyval ...string) error {
_, err := v.run1(dir, false, cmd, keyval) _, err := v.run1(dir, cmd, keyval)
return err return err
} }
// runOutput is like run but returns the output of the command. // runOutput is like run but returns the output of the command.
func (v *vcsCmd) runOutput(dir string, cmd string, keyval ...string) ([]byte, error) { func (v *vcsCmd) runOutput(dir string, cmd string, keyval ...string) ([]byte, error) {
return v.run1(dir, true, cmd, keyval) return v.run1(dir, cmd, keyval)
} }
// run1 is the generalized implementation of run and runOutput. // run1 is the generalized implementation of run and runOutput.
func (v *vcsCmd) run1(dir string, output bool, cmdline string, keyval []string) ([]byte, error) { func (v *vcsCmd) run1(dir string, cmdline string, keyval []string) ([]byte, error) {
m := make(map[string]string) m := make(map[string]string)
for i := 0; i < len(keyval); i += 2 { for i := 0; i < len(keyval); i += 2 {
m[keyval[i]] = keyval[i+1] m[keyval[i]] = keyval[i+1]
...@@ -187,7 +195,9 @@ func (v *vcsCmd) tags(dir string) ([]string, error) { ...@@ -187,7 +195,9 @@ func (v *vcsCmd) tags(dir string) ([]string, error) {
return nil, err return nil, err
} }
re := regexp.MustCompile(`(?m-s)` + tc.pattern) re := regexp.MustCompile(`(?m-s)` + tc.pattern)
tags = append(tags, re.FindAllString(string(out), -1)...) for _, m := range re.FindAllStringSubmatch(string(out), -1) {
tags = append(tags, m[1])
}
} }
return tags, nil return tags, nil
} }
...@@ -198,6 +208,20 @@ func (v *vcsCmd) tagSync(dir, tag string) error { ...@@ -198,6 +208,20 @@ func (v *vcsCmd) tagSync(dir, tag string) error {
if v.tagSyncCmd == "" { if v.tagSyncCmd == "" {
return nil return nil
} }
if tag != "" {
for _, tc := range v.tagLookupCmd {
out, err := v.runOutput(dir, tc.cmd, "tag", tag)
if err != nil {
return err
}
re := regexp.MustCompile(`(?m-s)` + tc.pattern)
m := re.FindStringSubmatch(string(out))
if len(m) > 1 {
tag = m[1]
break
}
}
}
if tag == "" && v.tagSyncDefault != "" { if tag == "" && v.tagSyncDefault != "" {
return v.run(dir, v.tagSyncDefault) return v.run(dir, v.tagSyncDefault)
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment