-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcompa.go
70 lines (57 loc) · 1.98 KB
/
compa.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
// SPDX-License-Identifier: Apache-2.0
// Copyright © 2021 Roberto Hidalgo <milpa@un.rob.mx>
package main
import (
"os"
"git.rob.mx/nidito/chinampa"
"git.rob.mx/nidito/chinampa/pkg/env"
"git.rob.mx/nidito/chinampa/pkg/logger"
"git.rob.mx/nidito/chinampa/pkg/runtime"
"git.rob.mx/nidito/chinampa/pkg/statuscode"
"github.com/unrob/milpa/internal/actions"
"github.com/unrob/milpa/internal/bootstrap"
_c "github.com/unrob/milpa/internal/constants"
"github.com/unrob/milpa/internal/errors"
"github.com/unrob/milpa/internal/lookup"
)
var version = "beta"
func logLevel() logger.Level {
if os.Getenv(env.Debug) == "trace" {
return logger.LevelTrace
} else if runtime.DebugEnabled() {
return logger.LevelDebug
}
return logger.LevelInfo
}
func main() {
logger.Configure("milpa", logLevel())
isDoctor := actions.DoctorModeEnabled()
logger.Debugf("doctor mode enabled: %v", isDoctor)
err := bootstrap.Run()
if err != nil {
errors.HandleExit(nil, err) // nolint: errcheck
return
}
cfg := chinampa.Config{
Name: "milpa",
Version: version,
Summary: "Runs commands found in " + _c.RepoRoot + " folders",
Description: `﹅milpa﹅ is a command-line tool to care for one's own garden of scripts, providing autocomplete, sub-commands, argument parsing and validation, along beautiful documentation—all it takes is a YAML spec and a script: bash or your language of choice.
See [﹅milpa help docs milpa﹅](/.milpa/docs/milpa/index.md) for more information about ﹅milpa﹅.`,
}
chinampa.SetErrorHandler(errors.HandleExit)
chinampa.SetVersionCommandName("__version")
chinampa.Register(actions.Doctor)
chinampa.Register(actions.Docs)
chinampa.Register(actions.CommandTree)
err = lookup.AllSubCommands(!isDoctor)
if err != nil && !isDoctor {
logger.Fatalf("Could not find subcommands: %s", err)
} else if err != nil {
logger.Error(err)
}
if err := chinampa.Execute(cfg); err != nil {
logger.Errorf("Could not boot milpa: %s", err)
os.Exit(statuscode.ConfigError)
}
}