1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2025-03-19 20:57:53 +02:00

63 lines
1.6 KiB
Go
Raw Normal View History

// Package dist provides checks to make sure the dist directory is always
2017-07-04 22:53:50 -03:00
// empty.
package dist
2017-07-04 22:53:50 -03:00
import (
"fmt"
"os"
"github.com/caarlos0/log"
"github.com/goreleaser/goreleaser/v2/pkg/context"
2017-07-04 22:53:50 -03:00
)
// CleanPipe cleans the distribution directory.
type CleanPipe struct{}
func (CleanPipe) Skip(ctx *context.Context) bool { return !ctx.Clean }
func (CleanPipe) String() string { return "cleaning distribution directory" }
func (CleanPipe) Run(ctx *context.Context) error {
// here we are setting a default outside a Default method...
// this is needed because when this run, the defaults are not set yet
// there's no good way of handling this...
_ = Pipe{}.Default(ctx)
return os.RemoveAll(ctx.Config.Dist)
}
// Pipe for dist.
2017-07-04 22:53:50 -03:00
type Pipe struct{}
func (Pipe) String() string { return "ensuring distribution directory" }
func (Pipe) Default(ctx *context.Context) error {
if ctx.Config.Dist == "" {
ctx.Config.Dist = "dist"
}
return nil
2017-07-04 22:53:50 -03:00
}
// Run the pipe.
func (Pipe) Run(ctx *context.Context) error {
_, err := os.Stat(ctx.Config.Dist)
2017-07-04 22:53:50 -03:00
if os.IsNotExist(err) {
log.Debugf("%s doesn't exist, creating empty directory", ctx.Config.Dist)
return mkdir(ctx)
2017-07-04 22:53:50 -03:00
}
files, err := os.ReadDir(ctx.Config.Dist)
2017-07-04 22:53:50 -03:00
if err != nil {
return err
2017-07-04 22:53:50 -03:00
}
2018-12-12 18:24:22 -02:00
if len(files) != 0 {
log.Debugf("there are %d files on %s", len(files), ctx.Config.Dist)
2017-07-04 22:53:50 -03:00
return fmt.Errorf(
"%s is not empty, remove it before running goreleaser or use the --clean flag",
2017-07-04 22:53:50 -03:00
ctx.Config.Dist,
)
}
log.Debugf("%s is empty", ctx.Config.Dist)
return mkdir(ctx)
}
func mkdir(ctx *context.Context) error {
// #nosec
return os.MkdirAll(ctx.Config.Dist, 0o755)
2017-07-04 22:53:50 -03:00
}