summaryrefslogtreecommitdiff
path: root/proposals/tree.md
diff options
context:
space:
mode:
authorPietro Gagliardi <[email protected]>2014-08-30 23:02:02 -0400
committerPietro Gagliardi <[email protected]>2014-08-30 23:02:02 -0400
commit77bf566ebbcb62acd4d08d905d9542d6ff9b6b80 (patch)
treeeeb8e72bc3bf57f5be7f0c0af4319189ac6de838 /proposals/tree.md
parent155899c65ed32245e2ccad4197a10c77017d835b (diff)
...in with the new.
Diffstat (limited to 'proposals/tree.md')
-rw-r--r--proposals/tree.md35
1 files changed, 35 insertions, 0 deletions
diff --git a/proposals/tree.md b/proposals/tree.md
new file mode 100644
index 0000000..a4752f6
--- /dev/null
+++ b/proposals/tree.md
@@ -0,0 +1,35 @@
+# Tree
+
+Unlike Table, Tree can only store a set of a single data type. (Blame Windows.)
+
+```go
+type TreeData struct {
+ Checked bool
+ Image ImageIndex
+ Text string
+ Children []TreeData // TODO does this need to be *[]TreeData?
+}
+```
+
+(the facilities for Images has yet to be designed)
+
+Tree itself will operate similarly to Table:
+
+```go
+type Tree struct {
+ Control
+ sync.Locker // with Unlock() refreshing the view
+ Data() *[]TreeData
+ SetHasCheckboxes(bool)
+ SetHasImages(bool)
+}
+```
+
+By default, a Tree only shows the Text field.
+
+A Tree path is just an `[]int` with each element set to the consecutive index in Children. For example:
+
+```go
+i := []int{3, 4, 5}
+value := tree.Data()[i[0]].Children[i[1]].Children[i[2]].Text
+```