summaryrefslogtreecommitdiff
path: root/debug.go
blob: 625a6632b63bc4bf6b93c33b1259954c168f3126 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
package main

import (
	"fmt"

	"go.wit.com/log"
	"go.wit.com/toolkits/tree"
	"go.wit.com/widget"
)

func dumpTree(n *tree.Node, draw bool) {
	w := n.TK.(*guiWidget)
	log.Log(ERROR, "dumpTree n", n.WidgetId, n.WidgetType, n.String())
	if w == nil {
		log.Log(ERROR, "dumpTree n.TK == nil", n.WidgetId, n.WidgetType, n.String())
		return
	}
	showWidgetPlacement(n, true, "dumpTree()")

	for _, child := range w.children {
		dumpTree(child.node, draw)
	}
}

func showWidgetPlacement(n *tree.Node, b bool, s string) {
	if n == nil {
		log.Log(ERROR, "WTF w == nil")
		return
	}
	w := n.TK.(*guiWidget)
	w.showWidgetPlacement(b, s)
}

func (w *guiWidget) showWidgetPlacement(b bool, s string) {
	var s1 string
	var pId int
	if w.node.Parent == nil {
		log.Log(INFO, "showWidgetPlacement() parent == nil", w.node.WidgetId, w.cuiName)
		pId = 0
	} else {
		pId = w.node.Parent.WidgetId
	}
	s1 = fmt.Sprintf("(wId,pId)=(%2d,%2d) ", w.node.WidgetId, pId)
	if w.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(" w.Visable() == false     ")
	}
	if w.node.Parent != nil {
		if w.node.Parent.WidgetType == widget.Grid {
			s1 += fmt.Sprintf("At(%2d,%2d) ", w.AtW, w.AtH)
		}
	}
	tmp := "." + w.String() + "."
	log.Log(INFO, s1, s, w.node.WidgetType, ",", tmp, "jcarr") // , "text=", w.text)
}

/*
func dumpWidget(n *tree.Node, 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 listWidgets(n *tree.Node) {
	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
}
*/