Tree Fields¶
General Syntax¶
Each tree field is a function with a list of input fields. These fields can be either tree fields or data fields. To avoid ambiguities it is good practice to name tree fields starting with a capital letter and data fields with a lower case letter. A tree field is always defined as part of a tree (see previous chapter). The definition states the name, the field type, and the input parameters:
field "Name"
field-type "type"
own-fields [...]
child-fields [...]
sibling-fields [...]
parent-fields [...]
The field is started by the line field "Name"
where “Name” is the name of the field. This will appear as the column heading in the tree list.
After this, indented with four spaces, is the field type: field-type "type"
, where “type” is the type (see next for an overview).
After this, the lines own-fields [...]
, child-fields [...]
, sibling-fields [...]
, and parent-fields [...]
each define a list of field names. These are the input parameters for the function. They are evaluated in the order they are mentioned. A real-world example:
field "Progress"
field-type "ratio-percent"
own-fields ["Spent Hours", "Planned Hours"]
child-fields []
sibling-fields []
parent-fields []
The tree field “Progress” is a ratio, defined as parameter1 / (parameter2 + parameter3 + …). In the tree view it will be displayed as a percentage. It shows the ratio of the tree fields “Spent Hours” / “Planned Hours”.
string¶
The simple display of the content of one or multiple data fields or tree fields. Syntax:
field "Name"
field-type "string"
own-fields ["field1"]
child-fields []
sibling-fields []
parent-fields []
Result: The values or strings found in the fields field1, field2, field3, …, put together, in the order they are mentioned.
url¶
Same as “string”, but in an html export the field is formated as url link (clickable).
text¶
Same as “string”, but the exported field has a larger width and can span several lines.
sum¶
The sum of all input fields. Syntax:
field "Name"
field-type "sum"
own-fields ["field1", "field2", ...]
child-fields ["field3", ...]
sibling-fields [...]
parent-fields [...]
were “field1”, “field2”, “field3”, …, are the names of data or tree fields. Fields must be integer fields, the result for string fields is not defined.
Result: The value field1 + field2 + field3 + ….
set¶
A list of unique occurrences of values of all input fields. Syntax:
field "Name"
field-type "set"
own-fields ["field1", "field2", ...]
child-fields ["field3", ...]
sibling-fields [...]
parent-fields [...]
were “field1”, “field2”, “field3”, …, are the names of data or tree fields.
Result: A list like value1, value2, value3, value4, where each value is the value of at least on input field and each value is listed only once, sorted alphabetically.
sum-time¶
Same as “sum”, but will show the result as hour format, e.g. the value 1.5 will be displayed and exported as 1:30:00.
difference¶
Difference of numbers. Syntax:
field "Name"
field-type "difference"
own-fields ["field1", "field2", ...]
child-fields ["field3", ...]
sibling-fields [...]
parent-fields [...]
were “field1”, “field2”, “field3”, …, are the names of data or tree fields.
Result: The value field1 - (field2 + field3 + …), in the order they are mentioned.
difference-time¶
Same as “difference”, but will show the result as hour format, e.g. the value 1.5 will be displayed and exported as 1:30:00.
mean¶
The statistical mean of all input fields. Syntax:
field "Name"
field-type "mean"
own-fields ["field1", "field2", ...]
child-fields ["field3", ...]
sibling-fields [...]
parent-fields [...]
were “field1”, “field2”, “field3”, …, are the names of data or tree fields.
Result: The value (field1 + field2 + field3 + …) / N, where N is the number of fields.
mean-percent¶
Same as “mean”, but will show the result as a percentage, e.g. the value 0.75 will show as 75 %.
min¶
The minimum. Syntax:
field "Name"
field-type "min"
own-fields ["field1", "field2", ...]
child-fields ["field3", ...]
sibling-fields [...]
parent-fields [...]
were “field1”, “field2”, “field3”, …, are the names of data or tree fields.
Result: The minimum value min(field1, field2, field3, …). This can only be for numbers. If you want to find the minimum of texts, use min-string.
max¶
The Maximum. Same as min, but displays the maximum.
min-string¶
The smallest of a list of strings. Same as min, but can be used for text, e.g., names of branches collected by a node-name field (see below). Comparison is alphabetically, “aaaab” is smaller than “bc”.
max-string¶
The largest of a list of strings. Same as min-string, but shows the maximum.
ratio¶
The ratio between the first and the sum of all following input fields. Syntax:
field "Name"
field-type "ratio"
own-fields ["field1", "field2", ...]
child-fields ["field3", ...]
sibling-fields [...]
parent-fields [...]
were “field1”, “field2”, “field3”, …, are the names of data or tree fields.
Result: The value field1 / (field2 + field3 + …), where N is the number of fields.
ratio-percent¶
Same as “ratio”, but displayed as percentage (e.g., 0.75 is displayed as 75 %).
node-name¶
The name of the node’s parent in another tree. Syntax:
field "Name"
field-type "node-name"
own-fields []
child-fields []
sibling-fields []
parent-fields [N]
were N is an integer number.
Result: Displays the name of the node’s parent in tree N. Trees are counted starting with 0.
Example: This field is called “Project” and is defined in a tree “Time”, which is the first tree (i.e. Tree 0). There is another tree called “Projects”, which is the third tree (i.e. Tree 2):
tree "Time"
field "Project"
field-type "node-name"
own-fields []
child-fields []
sibling-fields []
parent-fields [2]
tree "Tasks"
...
tree "Projects"
...
This would create the column “Project” in the tree view of the “Time” tree. The line parent-fields[2]
means each entry shows the respective node’s parent in the “Project” tree (e.g. “TreeTime”).
node-path¶
Same as “node-name”, but instead of the paren’t name, the entire path is shown, using “|” as delimiter (e.g. “Coding | Open Source | TreeTime”).