2017-01-21 19:11:54 -02:00
|
|
|
// Package source provides pipes to take care of validating the current
|
|
|
|
// git repo state.
|
2017-01-19 09:47:17 +01:00
|
|
|
// For the releasing process we need the files of the tag we are releasing.
|
|
|
|
package source
|
|
|
|
|
|
|
|
import (
|
2017-01-19 10:24:04 +01:00
|
|
|
"errors"
|
2017-01-19 09:47:17 +01:00
|
|
|
"os/exec"
|
|
|
|
|
|
|
|
"github.com/goreleaser/goreleaser/context"
|
|
|
|
)
|
|
|
|
|
2017-01-21 19:11:54 -02:00
|
|
|
// ErrDirty happens when the repo has uncommitted/unstashed changes
|
2017-01-21 19:13:07 -02:00
|
|
|
var ErrDirty = errors.New("git is currently in a dirty state, commit or stash your changes to continue")
|
2017-01-21 19:11:54 -02:00
|
|
|
|
2017-01-21 19:14:02 -02:00
|
|
|
var ErrWrongRef = errors.New("current tag ref is different from HEAD ref, checkout the latest tag to continue")
|
2017-01-21 19:11:54 -02:00
|
|
|
|
|
|
|
// Pipe to make sure we are in the latest Git tag as source.
|
|
|
|
type Pipe struct{}
|
2017-01-19 09:47:17 +01:00
|
|
|
|
|
|
|
// Description of the pipe
|
|
|
|
func (p *Pipe) Description() string {
|
2017-01-21 19:11:54 -02:00
|
|
|
return "Validating current git state"
|
2017-01-19 09:47:17 +01:00
|
|
|
}
|
|
|
|
|
2017-01-21 19:11:54 -02:00
|
|
|
// Run errors we the repo is dirty or if the current ref is different from the
|
|
|
|
// tag ref
|
2017-01-19 09:47:17 +01:00
|
|
|
func (p *Pipe) Run(ctx *context.Context) error {
|
|
|
|
cmd := exec.Command("git", "diff-index", "--quiet", "HEAD", "--")
|
2017-01-21 19:11:54 -02:00
|
|
|
if err := cmd.Run(); err != nil {
|
|
|
|
return ErrDirty
|
2017-01-19 09:47:17 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
cmd = exec.Command("git", "describe", "--exact-match", "--match", ctx.Git.CurrentTag)
|
2017-01-21 19:11:54 -02:00
|
|
|
if err := cmd.Run(); err != nil {
|
2017-01-21 19:13:39 -02:00
|
|
|
return ErrWrongRef
|
2017-01-19 10:24:04 +01:00
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|