diff options
| author | Jeff Carr <[email protected]> | 2023-02-25 14:05:25 -0600 |
|---|---|---|
| committer | Jeff Carr <[email protected]> | 2023-02-25 14:05:25 -0600 |
| commit | f3bb68396afa7452ecf1c8d4744c825a9d81057c (patch) | |
| tree | 00b55a17cee7a8e2f795c479a84a844779993c1c /debug_window.go | |
| parent | 355e5ec968427c2b07b78fec12224f31a65df740 (diff) | |
The debugging window is finally useful
the gui enabled debugging works
--gui-debug works from the command line
The debug window can now select things
debugging now includes widget types
all the debug flags work
finally working debugging flags via gui checkboxes
add debian packaging rules
use log() in the toolkit
use a standard log() to simplify debugging flags
add reference to 'GO Style Guide'
use the same LICENSE from the GO developers.
TODO: make this threadsafe
TODO: fix plugin stuff
Signed-off-by: Jeff Carr <[email protected]>
Diffstat (limited to 'debug_window.go')
| -rw-r--r-- | debug_window.go | 194 |
1 files changed, 194 insertions, 0 deletions
diff --git a/debug_window.go b/debug_window.go new file mode 100644 index 0000000..82d7557 --- /dev/null +++ b/debug_window.go @@ -0,0 +1,194 @@ +package gui + +var bugWin *Node +var mapWindows map[string]*Node + +/* + Creates a window helpful for debugging this package +*/ +func DebugWindow() { + Config.Title = "go.wit.org/gui debug window" + Config.Width = 300 + Config.Height = 200 + Config.Exit = StandardClose + bugWin = NewWindow() + bugWin.DebugTab("Debug Tab") +} + +var checkd, checkdn, checkdt, checkdtk *Node + +//////////////////////// debug flags ////////////////////////////////// +func debugFlags(n *Node) { + var df, checkdn, checkdd, changeCheckbox *Node + df = n.NewGroup("Debug Flags") + df.NewLabel("flags to control debugging output") + + cb := df.NewCheckbox("debugGui") + cb.custom = func() { + log(true, "custom ran correctly for =", n.Name) + debugGui = true + } + + checkdd = df.NewCheckbox("debugDump") + checkdd.custom = func() { + log(true, "debugDump() custom ran correctly for =", n.Name) + debugDump = true + } + + checkdn = df.NewCheckbox("debugNode") + checkdn.custom = func() { + log(true, "debugNode() custom ran correctly for =", n.Name) + debugNode = true + } + + + cb = df.NewCheckbox("debugChange") + cb.custom = func() { + log(true, "checkbox: custom() ran correctly for =", cb.Name) + log(true, "START debugChange =", debugChange) + if (debugChange) { + debugChange = false + SetDebugChange(false) + log(true, "debugToolkitChange turned off node.Name =", cb.Name) + } else { + debugChange = true + SetDebugChange(true) + log(true, "debugToolkitChange turned on Name =", cb.Name) + } + log(true, "END debugChange =", debugChange) + } + + cb = df.NewCheckbox("debugTabs") + cb.custom = func() { + log(true, "debugTabs() custom ran correctly for =", n.Name) + debugTabs = true + } + + cb = df.NewCheckbox("debugPlugin") + cb.custom = func() { + log(true, "debugPlugin() custom ran correctly for =", n.Name) + debugPlugin = true + } + + changeCheckbox = df.NewCheckbox("debugToolkit") + changeCheckbox.custom = func() { + SetDebugToolkit(true) + } + + df.NewButton("Debug Toolkit", func() { + if (debugToolkit) { + SetDebugToolkit(false) + log(true, "debugToolkit turned off node.Name =", n.Name) + } else { + SetDebugToolkit(true) + log(true, "debugToolkit turned on Name =", n.Name) + } + }) + + df.NewButton("Dump Debug Flags", func () { + ShowDebugValues() + }) +} + +func (n *Node) DebugTab(title string) *Node { + var newN, gog, g1, g2, g3, dd *Node + + // time.Sleep(1 * time.Second) + newN = n.NewTab(title) + newN.Dump() + +//////////////////////// main debug things ////////////////////////////////// + gog = newN.NewGroup("GOLANG") + gog.NewLabel("go language") + gog.NewButton("GO Language Debug", func () { + GolangDebugWindow() + }) + + gog.NewLabel("wit/gui package") + gog.NewButton("Demo toolkit andlabs/ui", func () { + // DemoToolkitWindow() + }) + + debugFlags(newN) + +//////////////////////// window debugging things ////////////////////////////////// + g1 = newN.NewGroup("Current Windows") + dd = g1.NewDropdown("Window Dropdown") + log(debugGui, "dd =", dd) + + // initialize the windows map if it hasn't been + if (mapWindows == nil) { + mapWindows = make(map[string]*Node) + } + + var dump = false + for _, child := range Config.master.children { + log(debugGui, "\t\t", child.id, child.Width, child.Height, child.Name) + if (child.parent != nil) { + log(debugGui, "\t\t\tparent =",child.parent.id) + } else { + log(debugGui, "\t\t\tno parent") + panic("no parent") + } + if (dump == true) { + child.Dump() + } + dd.AddDropdownName(child.Name) + mapWindows[child.Name] = child + } + + dd.SetDropdown(0) + + g2 = newN.NewGroup("Debug Window") + g2.NewButton("SetMargined(tab)", func () { + log(debugChange, "START SetMargined(tab)", g2.Name) + // name := dd.GetText() + name := dd.Widget.S + log(debugChange, "name =", name) + log(debugChange, "mapWindows[name] =", mapWindows[name]) + /* + for s, n := range mapWindows { + log(debugChange, "\tname =", name) + log(debugChange, "\tmapWindows s =", s) + log(debugChange, "\tmapWindows[s] =", n) + } + */ + bugWin = mapWindows[name] + log(debugChange, "END dd.Widget.S =", dd.Widget.S) + // gw.UiTab.SetMargined(*gw.TabNumber, true) + }) + g2.NewButton("Hide(tab)", func () { + log(debugChange, "\tclick() START", g2.Name) + // gw.UiTab.Hide() + }) + g2.NewButton("Show(tab)", func () { + // gw.UiTab.Show() + }) + g2.NewButton("Delete(tab)", func () { + // gw.UiTab.Delete(*gw.TabNumber) + }) + g2.NewButton("change Title", func () { + // mainWindow.SetText("hello world") + }) + + ///////////////////////////////////////////////////// + g3 = newN.NewGroup("Node Debug") + + g3.NewButton("Node.Dump()", func () { + debugGui = true + debugDump = true + bugWin.Dump() + }) + g3.NewButton("Node.ListChildren(false)", func () { + debugGui = true + debugDump = true + bugWin.ListChildren(false) + }) + g3.NewButton("Node.ListChildren(true)", func () { + debugGui = true + debugDump = true + bugWin.ListChildren(true) + }) + + return newN +} |
