diff --git a/cmd/main.go b/cmd/main.go index 8664ef1..5955ff2 100644 --- a/cmd/main.go +++ b/cmd/main.go @@ -136,7 +136,8 @@ func main() { deployable, e := newProtoDeployable(ctr, name, tag) if e != nil { - return cli.NewMultiError(e...) + printTerminalErrors(e) + return cli.NewExitError("Fatal error whilst generating NLDP format.", 1) } data, ex := proto.Marshal(deployable) if ex != nil { @@ -420,7 +421,8 @@ func main() { } else { deployment, _, errors := gh.Repositories.CreateDeployment(owner, reponame, &r) if errors != nil { - return cli.NewMultiError(errors) + printTerminalErrors([]error{errors}) + return cli.NewExitError("Fatal error encountered whilst creating deployment.", 1) } fmt.Println("Created deployment " + strconv.Itoa(*deployment.ID) + " on " + owner + "/" + reponame) } diff --git a/cmd/util.go b/cmd/util.go index c68271a..5510009 100644 --- a/cmd/util.go +++ b/cmd/util.go @@ -18,6 +18,7 @@ package main import ( "errors" + "fmt" "io/ioutil" "os" "regexp" @@ -140,3 +141,13 @@ func newProtoDeployable(imageUri string, unitName string, tag string) (*nelson.D }, }, nil } + +func printTerminalErrors(errs []error) { + for i, j := 0, len(errs)-1; i < j; i, j = i+1, j-1 { + errs[i], errs[j] = errs[j], errs[i] + } + + for _, e := range errs { + fmt.Println(e) + } +}