-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathmain.go
84 lines (73 loc) · 2 KB
/
main.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
package main
import (
"errors"
"fmt"
"io"
"log"
"os"
"github.com/DavidGamba/dgtools/bt/config"
"github.com/DavidGamba/dgtools/bt/stack"
stacksConfig "github.com/DavidGamba/dgtools/bt/stack/config"
"github.com/DavidGamba/dgtools/bt/terraform"
"github.com/DavidGamba/dgtools/buildutils"
"github.com/DavidGamba/dgtools/run"
"github.com/DavidGamba/go-getoptions"
)
var Logger = log.New(os.Stderr, "", log.LstdFlags)
func main() {
os.Exit(program(os.Args))
}
func program(args []string) int {
ctx, cancel, done := getoptions.InterruptContext()
defer func() { cancel(); <-done }()
// Read config and store it in context
cfg, _, err := config.Get(ctx, ".bt.cue")
if err != nil {
if !errors.Is(err, buildutils.ErrNotFound) {
fmt.Fprintf(os.Stderr, "ERROR: %s\n", err)
return 1
}
}
ctx = config.NewConfigContext(ctx, cfg)
// Read config and store it in context
stackCfg, _, err := stacksConfig.Get(ctx, "bt-stacks.cue")
if err != nil {
if !errors.Is(err, buildutils.ErrNotFound) {
fmt.Fprintf(os.Stderr, "ERROR: %s\n", err)
return 1
}
}
ctx = stacksConfig.NewConfigContext(ctx, stackCfg)
opt := getoptions.New()
opt.Self("", "Terraform build system built as a no lock-in wrapper")
opt.Bool("quiet", false, opt.GetEnv("QUIET"))
opt.SetUnknownMode(getoptions.Pass)
configCMD(ctx, opt)
terraform.NewCommand(ctx, opt)
stack.NewCommand(ctx, opt)
opt.HelpCommand("help", opt.Alias("?"))
remaining, err := opt.Parse(args[1:])
if err != nil {
fmt.Fprintf(os.Stderr, "ERROR: %s\n", err)
return 1
}
if opt.Called("quiet") {
Logger.SetOutput(io.Discard)
run.Logger.SetOutput(io.Discard)
config.Logger.SetOutput(io.Discard)
stack.Logger.SetOutput(io.Discard)
terraform.Logger.SetOutput(io.Discard)
}
err = opt.Dispatch(ctx, remaining)
if err != nil {
if errors.Is(err, getoptions.ErrorHelpCalled) {
return 1
}
fmt.Fprintf(os.Stderr, "ERROR: %s\n", err)
if errors.Is(err, getoptions.ErrorParsing) {
fmt.Fprintf(os.Stderr, "\n"+opt.Help())
}
return 1
}
return 0
}