Files
deej/pkg/deej/cmd/main.go

67 lines
1.4 KiB
Go

package main
import (
"flag"
"fmt"
"github.com/omriharel/deej/pkg/deej"
)
var (
gitCommit string
versionTag string
buildType string
verbose bool
)
func init() {
flag.BoolVar(&verbose, "verbose", false, "show verbose logs (useful for debugging serial)")
flag.BoolVar(&verbose, "v", false, "shorthand for --verbose")
flag.Parse()
}
func main() {
// first we need a logger
logger, err := deej.NewLogger(buildType)
if err != nil {
panic(fmt.Sprintf("Failed to create logger: %v", err))
}
named := logger.Named("main")
named.Debug("Created logger")
named.Infow("Version info",
"gitCommit", gitCommit,
"versionTag", versionTag,
"buildType", buildType)
// provide a fair warning if the user's running in verbose mode
if verbose {
named.Debug("Verbose flag provided, all log messages will be shown")
}
// create the deej instance
d, err := deej.NewDeej(logger, verbose)
if err != nil {
named.Fatalw("Failed to create deej object", "error", err)
}
// if injected by build process, set version info to show up in the tray
if buildType != "" && (versionTag != "" || gitCommit != "") {
identifier := gitCommit
if versionTag != "" {
identifier = versionTag
}
versionString := fmt.Sprintf("Version %s-%s", buildType, identifier)
d.SetVersion(versionString)
}
// onwards, to glory
if err = d.Initialize(); err != nil {
named.Fatalw("Failed to initialize deej", "error", err)
}
}