2024-01-01 16:11:54 -06:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"sync"
|
2024-01-17 21:31:49 -06:00
|
|
|
"runtime/debug"
|
|
|
|
|
2024-01-08 21:19:42 -06:00
|
|
|
"go.wit.com/log"
|
2024-01-05 13:30:00 -06:00
|
|
|
"go.wit.com/gui/widget"
|
2024-01-17 21:31:49 -06:00
|
|
|
"go.wit.com/gui/toolkits/tree"
|
2024-01-01 16:11:54 -06:00
|
|
|
|
2024-01-15 16:11:40 -06:00
|
|
|
"go.wit.com/dev/andlabs/ui"
|
2024-01-01 16:11:54 -06:00
|
|
|
// the _ means we only need this for the init()
|
2024-01-15 16:11:40 -06:00
|
|
|
_ "go.wit.com/dev/andlabs/ui/winmanifest"
|
2024-01-01 16:11:54 -06:00
|
|
|
)
|
|
|
|
|
|
|
|
var uiMainUndef bool = true
|
|
|
|
var uiMain sync.Once
|
|
|
|
var muAction sync.Mutex
|
|
|
|
|
2024-01-15 16:11:40 -06:00
|
|
|
func queueMain(currentA widget.Action) {
|
|
|
|
defer func() {
|
|
|
|
if r := recover(); r != nil {
|
2024-01-17 21:31:49 -06:00
|
|
|
log.Warn("YAHOOOO Recovered in queueMain() application:", r)
|
|
|
|
log.Println("Recovered from panic:", r)
|
|
|
|
log.Println("Stack trace:")
|
|
|
|
debug.PrintStack()
|
|
|
|
me.myTree.DoToolkitPanic()
|
2024-01-15 16:11:40 -06:00
|
|
|
}
|
|
|
|
}()
|
|
|
|
ui.QueueMain( func() {
|
|
|
|
rawAction(¤tA)
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func guiMain() {
|
|
|
|
defer func() {
|
|
|
|
if r := recover(); r != nil {
|
2024-01-17 21:31:49 -06:00
|
|
|
log.Warn("YAHOOOO Recovered in guiMain application:", r)
|
|
|
|
log.Println("Recovered from panic:", r)
|
|
|
|
log.Println("Stack trace:")
|
|
|
|
debug.PrintStack()
|
|
|
|
me.myTree.DoToolkitPanic()
|
2024-01-15 16:11:40 -06:00
|
|
|
}
|
|
|
|
}()
|
|
|
|
ui.Main(func() {
|
|
|
|
demoUI()
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2024-01-17 21:31:49 -06:00
|
|
|
func Init() {
|
|
|
|
log.Warn("Init() TODO: move init() to here")
|
|
|
|
}
|
|
|
|
|
2024-01-01 16:11:54 -06:00
|
|
|
// This is important. This sets the defaults for the gui. Without this, there isn't correct padding, etc
|
|
|
|
func init() {
|
2024-01-08 21:19:42 -06:00
|
|
|
log.Log(INFO, "Init() START")
|
|
|
|
log.Log(INFO, "Init()")
|
2024-01-01 16:11:54 -06:00
|
|
|
// Can you pass values to a plugin init() ? Otherwise, there is no way to safely print
|
2024-01-08 21:19:42 -06:00
|
|
|
// log.Log(INFO, "init() Setting defaultBehavior = true")
|
2024-01-01 16:11:54 -06:00
|
|
|
setDefaultBehavior(true)
|
|
|
|
|
2024-01-17 21:31:49 -06:00
|
|
|
me.myTree = tree.New()
|
|
|
|
me.myTree.PluginName = "andlabs"
|
|
|
|
me.myTree.ActionFromChannel = queueMain
|
|
|
|
|
2024-01-01 16:11:54 -06:00
|
|
|
// TODO: this is messed up. run ui.Main() from the first add? Initialize it with an empty thing first?
|
|
|
|
// fake out the OS toolkit by making a fake window. This is probably needed for macos & windows
|
|
|
|
// actually, this probably breaks the macos build
|
2024-01-15 16:11:40 -06:00
|
|
|
go guiMain()
|
2024-01-01 16:11:54 -06:00
|
|
|
}
|