go-deb/main.go

100 lines
1.9 KiB
Go
Raw Normal View History

2024-02-11 01:00:05 -06:00
package main
import (
"embed"
"os"
"path/filepath"
2024-02-11 01:00:05 -06:00
"go.wit.com/gui"
"go.wit.com/lib/debugger"
"go.wit.com/lib/gadgets"
2024-03-01 07:44:02 -06:00
"go.wit.com/lib/gui/shell"
2024-02-11 01:00:05 -06:00
"go.wit.com/log"
)
2024-11-07 07:03:13 -06:00
// sent from -ldflags
var VERSION string
2024-11-15 10:51:45 -06:00
var DATE string
2024-11-07 07:03:13 -06:00
2024-02-11 01:00:05 -06:00
// This is the beginning of the binary tree of GUI widgets
var myGui *gui.Node
var cBox *controlBox
2024-02-11 01:00:05 -06:00
// this is a basic window. the user can open and close it
var basicWindow *gadgets.BasicWindow
//go:embed resources/*
var resources embed.FS
2024-02-11 01:00:05 -06:00
func main() {
if argv.Repo == "" {
log.Info("You need to tell me what repo you want to work on")
println("")
println("go-deb --repo go.wit.com/apps/helloworld")
os.Exit(0)
}
2024-02-11 01:00:05 -06:00
myGui = gui.New()
if !argv.NoGui {
myGui.InitEmbed(resources)
myGui.Default()
}
2024-02-11 01:00:05 -06:00
basicWindow = makebasicWindow()
// todo: add the go.work file logic here
homeDir, _ := os.UserHomeDir()
filepath := filepath.Join(homeDir, "go/src", argv.Repo)
os.Chdir(filepath)
// scan the repo
cBox.addRepo(argv.Repo)
2024-02-20 23:13:26 -06:00
// look for a 'config' file in the repo
if cBox.readControlFile() == nil {
log.Warn("scan worked")
} else {
log.Warn("scan failed")
}
cBox.computeControlValues()
// verify the values for the package
if cBox.status == nil {
log.Info("argv.Repo =", argv.Repo)
log.Info("repo not found. Try:")
log.Info("")
log.Info(" go-clone", argv.Repo)
log.Info("")
os.Exit(-1)
}
// set the working directory to argv.Repo
log.Info("cd", cBox.status.Path())
os.Chdir(cBox.status.Path())
if argv.NoGui {
2024-02-23 22:07:13 -06:00
shell.TestTerminalColor()
// basicWindow.Show() // broken gui package. convert to protobuf
2024-03-02 15:58:56 -06:00
if ok, err := cBox.buildPackage(); ok {
2024-11-06 17:51:49 -06:00
log.Info("build worked")
} else {
2024-03-01 07:44:02 -06:00
log.Warn("build failed:", err)
2024-02-20 23:13:26 -06:00
os.Exit(-1)
}
os.Exit(0)
2024-02-11 01:00:05 -06:00
}
// run the debugger if triggered from the commandline
if debugger.ArgDebug() {
go func() {
log.Sleep(2)
debugger.DebugWindow()
}()
}
basicWindow.Show()
// go will sit here until the window exits
gui.Watchdog()
os.Exit(0)
2024-02-11 01:00:05 -06:00
}