From 20f13a4b5be1a986e1085214f492a0afe6db322f Mon Sep 17 00:00:00 2001 From: Jeff Carr Date: Sun, 12 Mar 2023 08:47:16 -0500 Subject: Squashed commit of the following: commit 448abc843e2241bab6c399f7a836dccba1defc18 Author: Jeff Carr Date: Sun Mar 12 08:35:28 2023 -0500 this should probably be a new release now Signed-off-by: Jeff Carr commit a4064f7a6c5ac67437768aa2bc67c75dafc91c4c Author: Jeff Carr Date: Sat Mar 11 03:18:23 2023 -0600 able to work on add 'Box' and play with 'Image' Signed-off-by: Jeff Carr commit 6e59573d85e82ecb005805f50711dddc2df50480 Author: Jeff Carr Date: Sat Mar 11 03:04:34 2023 -0600 rearrange widget debugging Signed-off-by: Jeff Carr commit e0570de75c6eb1b4f49e541d9ef5d83ae4434d3d Author: Jeff Carr Date: Sat Mar 11 02:29:20 2023 -0600 debugging is lots smarter Signed-off-by: Jeff Carr commit ece32a1e43d91cd197d0a8497ad2f034c46126e1 Author: Jeff Carr Date: Fri Mar 10 21:38:23 2023 -0600 first pass on a node delete Signed-off-by: Jeff Carr commit c91cb0eddb0f73f8dea9b21a16cd76c7e2c19a33 Author: Jeff Carr Date: Fri Mar 10 21:06:29 2023 -0600 can recreate window list Signed-off-by: Jeff Carr commit 470f9dc26aefd3626b319264fe151aa48d4d5377 Author: Jeff Carr Date: Fri Mar 10 12:07:34 2023 -0600 attempt to ressurect mouse in the console plugin Signed-off-by: Jeff Carr commit 747bb53e06dda458cc8cd77b665f4d9d07f5e925 Author: Jeff Carr Date: Fri Mar 10 10:47:14 2023 -0600 jesus. gocui actually builds and works again as a plugin it didn't take too much to change it Signed-off-by: Jeff Carr commit 9283c65c8e9b8d2630b251ad952b6b52caddb307 Author: Jeff Carr Date: Fri Mar 10 07:26:53 2023 -0600 show/hide/etc for window widgets Signed-off-by: Jeff Carr commit 5724cd7ffd8595ae049a7c9c21cb2f1a993c4b76 Author: Jeff Carr Date: Fri Mar 10 06:40:36 2023 -0600 compiles and runs Signed-off-by: Jeff Carr commit 44a5e69ce17cb506adfe24ca72cc86caa9ebcc70 Author: Jeff Carr Date: Fri Mar 10 05:57:15 2023 -0600 more debugging improvements Signed-off-by: Jeff Carr commit b86f145f0252e7545b2e7fa78e1d5960cacb7bad Author: Jeff Carr Date: Fri Mar 10 03:42:32 2023 -0600 set margin on tab's works Signed-off-by: Jeff Carr commit d2218c08cf44acd5f017a8faa1439ee6d2fd46d5 Author: Jeff Carr Date: Thu Mar 9 16:26:21 2023 -0600 ignore all *.so files Signed-off-by: Jeff Carr commit e21934fff3cfea30b04df01bf0714f6927aa78f4 Author: Jeff Carr Date: Thu Mar 9 16:25:15 2023 -0600 can't embed the toolkit/*.so files here Signed-off-by: Jeff Carr commit f1e6c5fc9c8ca36db3ad6109d64612b6850fa856 Author: Jeff Carr Date: Thu Mar 9 16:21:14 2023 -0600 andlabs group widget has Show() and Hide() Signed-off-by: Jeff Carr commit e8487504aa76ca99c4891b777585a428fda0ef62 Author: Jeff Carr Date: Thu Mar 9 16:07:56 2023 -0600 pass the node id into the plugin to use in channels Signed-off-by: Jeff Carr commit 3667940a77af4e3855facb9247771d595477302f Author: Jeff Carr Date: Thu Mar 9 14:20:21 2023 -0600 fix SetText() on Label Signed-off-by: Jeff Carr commit 311d6be66db84b63fb7124df64e2e9be0f0b76a4 Author: Jeff Carr Date: Thu Mar 9 14:06:46 2023 -0600 still compiles and runs Signed-off-by: Jeff Carr commit ee4e9b21ef59a97f902c6dae2a57ac7b3063fe3b Author: Jeff Carr Date: Thu Mar 9 11:02:34 2023 -0600 compiles Signed-off-by: Jeff Carr Signed-off-by: Jeff Carr --- debug.go | 89 ++++++++++++++++++++++++++++++++++++++++++---------------------- 1 file changed, 59 insertions(+), 30 deletions(-) (limited to 'debug.go') diff --git a/debug.go b/debug.go index de78d89..19c119b 100644 --- a/debug.go +++ b/debug.go @@ -17,7 +17,6 @@ var debugTabs bool = false var debugFlags bool = false var debugChange bool = false // shows user events like mouse and keyboard var debugPlugin bool = false -var debugToolkit bool = false // for printing out the binary tree var listChildrenParent *Node @@ -26,28 +25,42 @@ var defaultPadding = " " func SetDebug (s bool) { debugGui = s - debugDump = s debugTabs = s - debugPlugin = s - debugNode = s - debugToolkit = s + SetFlag("Node", s) + SetFlag("Tabs", s) + SetFlag("Dump", s) SetFlag("Flags", s) - SetFlag("Toolkit", s) + SetFlag("Plugin", s) SetFlag("Change", s) SetFlag("Error", s) + + // This flag is only for the internal toolkit debugging + SetFlag("Toolkit", s) } func SetFlag (s string, b bool) { switch s { + case "Toolkit": + // This flag is only for internal toolkit debugging + case "Tabs": + debugTabs = b + case "Node": + debugNode = b + case "Dump": + debugDump = b case "Error": debugError = b case "Change": debugChange = b + case "Flags": + debugFlags = b + case "Plugin": + debugPlugin = b case "Show": - // print them here? For now, just used to print settings in the plugins + // ShowDebugValues() // print them here? default: - log(debugError, "Can't set unknown flag", s) + log(debugGui, "Can't set unknown flag", s) } // send the flag to the toolkit @@ -69,7 +82,6 @@ func ShowDebugValues() { log(true, "DebugTabs =", debugTabs) log(true, "DebugPlugin =", debugPlugin) log(true, "DebugNode =", debugNode) - log(true, "DebugToolkit =", debugToolkit) SetFlag("Show", true) } @@ -79,21 +91,24 @@ func (n *Node) Dump() { return } Indent("NODE DUMP START") - Indent("id = ", n.id) - Indent("Name = ", n.Name) - Indent("Width = ", n.Width) - Indent("Height = ", n.Height) + Indent("id = ", n.id) + Indent("Name = ", n.Name) + Indent("Width = ", n.Width) + Indent("Height = ", n.Height) + Indent("Widget Name = ", n.widget.Name) + Indent("Widget Type = ", n.widget.Type) + Indent("Widget Id = ", n.widget.GetId()) if (n.parent == nil) { - Indent("parent = nil") + Indent("parent = nil") } else { - Indent("parent.id =", n.parent.id) + Indent("parent.id =", n.parent.id) } if (n.children != nil) { - Indent("children = ", n.children) + Indent("children = ", n.children) } if (n.Custom != nil) { - Indent("Custom = ", n.Custom) + Indent("Custom = ", n.Custom) } Indent("NODE DUMP END") } @@ -102,8 +117,8 @@ func Indent(a ...interface{}) { logindent(listChildrenDepth, defaultPadding, a...) } -func (n *Node) dumpWidget() { - var info string +func (n *Node) dumpWidget() string { + var info, d string info = n.widget.Type.String() @@ -115,25 +130,39 @@ func (n *Node) dumpWidget() { info += " = " + strconv.FormatBool(n.widget.B) } + d = strconv.Itoa(n.id) + " " + info + + var tabs string + for i := 0; i < listChildrenDepth; i++ { + tabs = tabs + defaultPadding + } + d = tabs + d logindent(listChildrenDepth, defaultPadding, n.id, info) + return d } -func (n *Node) ListChildren(dump bool) { - n.dumpWidget() +func (n *Node) ListChildren(dump bool, dropdown *Node, mapNodes map[string]*Node) { + s := n.dumpWidget() + if (dropdown != nil) { + dropdown.AddDropdownName(s) + if (mapNodes != nil) { + mapNodes[s] = n + } + } if (dump == true) { n.Dump() } if len(n.children) == 0 { if (n.parent == nil) { - } else { - log(debugNode, "\t\t\tparent =",n.parent.id) - if (listChildrenParent != nil) { - log(debugNode, "\t\t\tlistChildrenParent =",listChildrenParent.id) - if (listChildrenParent.id != n.parent.id) { - // log("parent.child does not match child.parent") - exit("parent.child does not match child.parent") - } + return + } + log(debugNode, "\t\t\tparent =",n.parent.id) + if (listChildrenParent != nil) { + log(debugNode, "\t\t\tlistChildrenParent =",listChildrenParent.id) + if (listChildrenParent.id != n.parent.id) { + // log("parent.child does not match child.parent") + exit("parent.child does not match child.parent") } } log(debugNode, "\t\t", n.id, "has no children") @@ -158,7 +187,7 @@ func (n *Node) ListChildren(dump bool) { } listChildrenParent = n listChildrenDepth += 1 - child.ListChildren(dump) + child.ListChildren(dump, dropdown, mapNodes) listChildrenDepth -= 1 } return -- cgit v1.2.3