Form file "form1.per":
LAYOUT
GRID
{
<Tree t1 >
Name Index
[c1 |c2 ]
[c1 |c2 ]
[c1 |c2 ]
[c1 |c2 ]
}
END
END
ATTRIBUTES
LABEL c1 = FORMONLY.name;
LABEL c2 = FORMONLY.idx;
PHANTOM FORMONLY.pid;
PHANTOM FORMONLY.id;
PHANTOM FORMONLY.exp;
TREE t1: tree1
IMAGEEXPANDED = "open",
IMAGECOLLAPSED = "folder",
IMAGELEAF = "file",
PARENTIDCOLUMN = pid,
IDCOLUMN = id,
EXPANDEDCOLUMN = exp;
END
INSTRUCTIONS
SCREEN RECORD sr_tree(name, pid, id, idx, exp);
END
Static tree
DISPLAY ARRAY:
DEFINE tree DYNAMIC ARRAY OF RECORD
name STRING,
pid STRING,
id STRING,
idx INTEGER,
expanded BOOLEAN
END RECORD
MAIN
OPEN FORM f FROM "form1"
DISPLAY FORM f
CALL fill(4)
DISPLAY ARRAY tree TO sr_tree.* ATTRIBUTE(UNBUFFERED)
BEFORE ROW
DISPLAY "Current row: ", arr_curr()
END DISPLAY
END MAIN
FUNCTION fill(max_level)
DEFINE max_level, p INTEGER
CALL tree.clear()
LET p = fill_tree(max_level, 1, 0, NULL)
END FUNCTION
FUNCTION fill_tree(max_level, level, p, pid)
DEFINE max_level, level INTEGER
DEFINE p INTEGER
DEFINE i INTEGER
DEFINE id, pid STRING
DEFINE name STRING
IF level < max_level THEN
LET name = "Node "
ELSE
LET name = "Leaf "
END IF
FOR i = 1 TO level
LET p = p + 1
IF pid IS NULL THEN
LET id = i
ELSE
LET id = pid || "." || i
END IF
LET tree[p].id = id
LET tree[p].pid = pid
LET tree[p].idx = p
LET tree[p].expanded = FALSE
LET tree[p].name = name || level || '.' || i
IF level < max_level THEN
LET p = fill_tree(max_level, level + 1, p, id)
END IF
END FOR
RETURN p
END FUNCTION