package main import ( "fmt" "go.wit.com/log" "go.wit.com/gui/widget" ) func (n *node) dumpTree(draw bool) { w := n.tk if (w == nil) { return } n.showWidgetPlacement(true, "dumpTree()") for _, child := range n.children { child.dumpTree(draw) } } func (n *node) showWidgetPlacement(b bool, s string) { if (n == nil) { log.Log(ERROR, "WTF w == nil") return } w := n.tk var s1 string var pId int if (n.parent == nil) { log.Log(INFO, "showWidgetPlacement() parent == nil", n.WidgetId, w.cuiName) pId = 0 } else { pId = n.parent.WidgetId } s1 = fmt.Sprintf("(wId,pId)=(%2d,%2d) ", n.WidgetId, pId) if n.Visible() { s1 += fmt.Sprintf("gocui=(%2d,%2d)(%2d,%2d,%2d,%2d)", w.gocuiSize.Width(), w.gocuiSize.Height(), w.gocuiSize.w0, w.gocuiSize.h0, w.gocuiSize.w1, w.gocuiSize.h1) } else { s1 += fmt.Sprintf(" ") } if (n.parent != nil) { if (n.parent.WidgetType == widget.Grid) { s1 += fmt.Sprintf("At(%2d,%2d) ", n.AtW, n.AtH) } } tmp := "." + n.progname + "." log.Log(INFO, s1, s, n.WidgetType, ",", tmp) // , "text=", w.text) } func (n *node) dumpWidget(pad string) { log.Log(NOW, "node:", pad, n.WidgetId, "At(", n.AtW, n.AtH, ") ,", n.WidgetType, ", n.progname =", n.progname, ", n.label =", n.label) } func (n *node) listWidgets() { if (n == nil) { return } var pad string for i := 0; i < me.depth; i++ { pad = pad + " " } n.dumpWidget(pad) for _, child := range n.children { me.depth += 1 child.listWidgets() me.depth -= 1 } return }