gocui/debug.go

107 lines
2.9 KiB
Go
Raw Normal View History

2025-02-01 11:42:31 -06:00
// Copyright 2017-2025 WIT.COM Inc. All rights reserved.
// Use of this source code is governed by the GPL 3.0
package main
import (
"fmt"
2025-02-05 07:24:14 -06:00
"github.com/awesome-gocui/gocui"
"go.wit.com/log"
"go.wit.com/widget"
)
func (w *guiWidget) dumpTree(s string) {
// log.Log(ERROR, "dump w", w.node.WidgetId, w.WidgetType, w.String())
if w == nil {
log.Log(ERROR, "dump w.TK == nil", w.node.WidgetId, w.node.WidgetType, w.String())
return
}
w.dumpWidget("dumpTree() " + s)
for _, child := range w.children {
child.dumpTree(s)
}
}
2025-02-05 15:55:56 -06:00
func (w *guiWidget) dumpWindows(s string) {
// log.Log(ERROR, "dump w", w.node.WidgetId, w.WidgetType, w.String())
if w == nil {
log.Log(ERROR, "dump w.TK == nil", w.node.WidgetId, w.node.WidgetType, w.String())
return
}
if w.node.WidgetType == widget.Window {
2025-02-05 16:30:06 -06:00
s += fmt.Sprintf(" F(%d,%d)", w.force.w0, w.force.h0)
// can't set this here. doesn't work
// w.full.w0 = w.force.w0
// w.full.h0 = w.force.h0
2025-02-05 15:55:56 -06:00
w.dumpWidget("dumpWindow() " + s)
2025-02-05 16:30:06 -06:00
w.windowFrame.dumpWidget("dumpFrame() " + s)
2025-02-05 15:55:56 -06:00
}
for _, child := range w.children {
child.dumpWindows(s)
}
}
// a standard function to print out information about a widget
2025-02-03 10:55:50 -06:00
func (tk *guiWidget) dumpWidget(s string) {
var s1 string
var pId int
2025-02-04 15:48:14 -06:00
// tk.verifyRect()
2025-02-03 10:55:50 -06:00
if tk.node.Parent == nil {
2025-02-05 07:24:14 -06:00
log.Logf(WARN, "showWidgetPlacement() parent == nil wId=%d cuiName=%s", tk.node.WidgetId, tk.cuiName)
pId = 0
} else {
2025-02-03 10:55:50 -06:00
pId = tk.node.Parent.WidgetId
}
2025-02-03 10:55:50 -06:00
s1 = fmt.Sprintf("(wId,pId)=(%4d,%4d) ", tk.node.WidgetId, pId)
sizeW, sizeH := tk.Size()
hide := "S"
if tk.Hidden() {
hide = "H"
}
s1 += fmt.Sprintf("size=(%3d,%3d)%s)", sizeW, sizeH, hide)
2025-02-03 10:55:50 -06:00
if tk.Visible() {
s1 += fmt.Sprintf("gocui=(%3d,%3d,%3d,%3d)",
2025-02-03 10:55:50 -06:00
tk.gocuiSize.w0, tk.gocuiSize.h0, tk.gocuiSize.w1, tk.gocuiSize.h1)
} else {
s1 += fmt.Sprintf(" %3s %3s %3s %3s ", "", "", "", "")
}
2025-02-04 15:48:14 -06:00
s1 += fmt.Sprintf(" full=(%3d,%3d,%3d,%3d)", tk.full.w0, tk.full.h0, tk.full.w1, tk.full.h1)
2025-02-03 10:55:50 -06:00
if tk.node.Parent != nil {
if tk.node.Parent.WidgetType == widget.Grid {
2025-02-06 19:34:26 -06:00
s1 += fmt.Sprintf("At(%3d,%3d)", tk.node.State.AtW, tk.node.State.AtH)
s1 += fmt.Sprintf("(%3d,%3d) ", tk.parent.widths[tk.node.State.AtW], tk.parent.heights[tk.node.State.AtH])
2025-01-29 07:55:56 -06:00
} else {
2025-02-06 19:34:26 -06:00
s1 += fmt.Sprintf(" %3s %3s ", "", "")
s1 += fmt.Sprintf(" %3s %3s ", "", "")
}
2025-01-29 07:55:56 -06:00
} else {
s1 += fmt.Sprintf(" %3s %3s ", "", "")
}
var end string
2025-02-03 10:55:50 -06:00
if tk.node.WidgetType == widget.Box {
2025-02-06 14:19:43 -06:00
end = fmt.Sprintf("%-8s %-8s %s", tk.node.WidgetType, tk.cuiName, tk.node.State.Direction.String())
} else {
2025-02-03 10:55:50 -06:00
curval := tk.String()
if curval == "" {
2025-02-03 10:55:50 -06:00
curval = tk.node.GetLabel()
}
2025-02-06 14:19:43 -06:00
end = fmt.Sprintf("%-8s %-8s %s", tk.node.WidgetType, tk.cuiName, tk.String())
}
2025-02-05 07:24:14 -06:00
log.Log(GOCUI, s1, s, end)
}
func printWidgetTree(g *gocui.Gui, v *gocui.View) error {
me.treeRoot.ListWidgets()
return nil
}
func printWidgetPlacements(g *gocui.Gui, v *gocui.View) error {
w := me.treeRoot.TK.(*guiWidget)
w.dumpTree("MM")
2025-02-05 15:55:56 -06:00
w.dumpWindows("WW")
2025-02-05 07:24:14 -06:00
return nil
}