1
0
mirror of https://github.com/goreleaser/goreleaser.git synced 2025-01-10 03:47:03 +02:00
goreleaser/cmd/config.go
Carlos Alexandro Becker 4266634752
feat: improve output (#4206)
- improves deprecation warning styles a bit so they caught the readers
eye faster and are easier to read
- warns if the user uses `builds.target` in conjunction with other
options which are ignored in that case
- improved env output
- improved no configuration found warning

some of the changes:

<img width="1263" alt="CleanShot 2023-07-24 at 21 38 41@2x"
src="https://github.com/goreleaser/goreleaser/assets/245435/40465853-7177-44d6-b07b-61b67590669a">

---------

Signed-off-by: Carlos Alexandro Becker <caarlos0@users.noreply.github.com>
2023-07-25 08:26:44 -03:00

45 lines
1.0 KiB
Go

package cmd
import (
"errors"
"io/fs"
"os"
"github.com/caarlos0/log"
"github.com/goreleaser/goreleaser/internal/logext"
"github.com/goreleaser/goreleaser/pkg/config"
)
func loadConfig(path string) (config.Project, error) {
p, _, err := loadConfigCheck(path)
return p, err
}
func loadConfigCheck(path string) (config.Project, string, error) {
if path == "-" {
log.Info("loading config from stdin")
p, err := config.LoadReader(os.Stdin)
return p, path, err
}
if path != "" {
p, err := config.Load(path)
return p, path, err
}
for _, f := range [4]string{
".goreleaser.yml",
".goreleaser.yaml",
"goreleaser.yml",
"goreleaser.yaml",
} {
proj, err := config.Load(f)
if err != nil && errors.Is(err, fs.ErrNotExist) {
continue
}
return proj, f, err
}
// the user didn't specify a config file and the known possible file names
// don't exist, so, return an empty config and a nil err.
log.Warn(logext.Warning("could not find a configuration file, using defaults..."))
return config.Project{}, "", nil
}