Programmer Guide/Shell Items/Table/TABLE Item Attributes: Difference between revisions
No edit summary |
|||
(64 intermediate revisions by 4 users not shown) | |||
Line 1: | Line 1: | ||
{{ | {{Table Item}} | ||
== Table attributes == | |||
Generally, table attributes, and table entries, are retrieved in the following way: | |||
#target := $#table[…] | |||
=== Overview === | |||
{|class="einrahmen" | |||
| valign="top" | <code>$#table[!<var>ATTRIBUTE</var>'']</code> | |||
| retrieves the respective attribute <var>ATTRIBUTE</var>; see below for the list of available attributes. | |||
|- | |||
| valign="top" | <code>$#table[]</code> | |||
| retrieves the number of entries in a table (bluntly put: its size) | |||
|- | |||
| valign="top" | <code>$#table[$<var>#index</var>, $<var>#fieldid</var>]</code> | |||
| This expression will return the value of field <var>fieldid</var> (named by its index, or by its name) of entry <var>index</var> (a number in the range <code>0…$#table[]-1</code>). | |||
|- | |||
| valign="top" | <code>$#table[$#index, !TAGGED]</code> | |||
| this expression evaluates to 1 if entry index is tagged, and to 0 otherwise. | |||
|- | |||
| valign="top" | <code>$#table[$#index]</code> | |||
| For a ''simple'' table, this expression returns the entry at the respective index. For ''extended'' tables, the return value depends on the mode: for extended tables in ''data-access mode,'' the value of ''all'' fields of the respective entry are returned, the result depending on the selected format (<code>SHOW</code> or <code>WRITE</code>); for extended tables in ''configuration mode,'' the expression will return the configuration of the field referenced by <code>index</code> (index being the numerical index, or the name, of the desired field). The format of the result is the same as for attribute <code>!FIELD</code>. | |||
|} | |||
=== List of attributes === | |||
{|class="einrahmen" | {|class="einrahmen" | ||
Line 31: | Line 33: | ||
| colspan="2" | The number of entries per memory chunk used for growing the table when the allocated memory runs out. This is the value passed to <code>NEW table</code> with the option <code>/N=m</code>. | | colspan="2" | The number of entries per memory chunk used for growing the table when the allocated memory runs out. This is the value passed to <code>NEW table</code> with the option <code>/N=m</code>. | ||
|- | |- | ||
| <var>!DIRECTORY</var> | | rowspan="2" | <var>!DIRECTORY</var> | ||
| <code>1</code> || if table is a segment directory | |||
|- | |||
| <code>0</code> || otherwise | |||
|- | |- | ||
| <var>!EDITABLE</var> | | <var>!EDITABLE</var> | ||
Line 56: | Line 60: | ||
Also see the example script <code>editabletable.sts</code> for a complete example. | Also see the example script <code>editabletable.sts</code> for a complete example. | ||
|- | |||
| rowspan="2" | <var>!EXTENDED</var> | |||
| <code>1</code> || if table is an extended table | |||
|- | |||
| <code>0</code> || otherwise | |||
|- | |||
| rowspan="9" | <var>!FIELDS</var> | |||
| colspan="2" | The <code>!FIELDS</code> attribute returns the number of defined fields (note that this is the same as <code>!NCOL</code>). | |||
If specified with a field name or index (e.g. <code>$#table[!FIELDS,$#fieldId]</code>), then the configuration for that field is returned in the format <var>type name show showname scale format [mvalue msymbol]</var>. Here the respective fields have the following meanings: | |||
<var>type name show showname scale format [mvalue msymbol]</var> | |||
|- | |- | ||
|type | |type | ||
|numeric type id (0=undefined, 1=NAME, 2=STRING, 3=INTEGER, 4=NUMBER) | |numeric type id (0=undefined, 1=NAME, 2=STRING, 3=INTEGER, 4=NUMBER) | ||
|- | |- | ||
|name | | <code>name</code> | ||
|field name | | field name | ||
|- | |- | ||
|show | | <code>show</code> | ||
|1 if field is included in show format | | 1 if field is included in show format | ||
|- | |- | ||
|showname | | <code>showname</code> | ||
|1 if name is included in show format | | 1 if name is included in show format | ||
|- | |- | ||
|scale | | <code>scale</code> | ||
|show scaling factor for numeric types | | show scaling factor for numeric types | ||
|- | |- | ||
|format | | <code>format</code> | ||
|format string used for show | | format string used for show | ||
|- | |- | ||
|mvalue, | | <code>mvalue, | ||
msymbol | msymbol</code> | ||
|missing value and | | missing value and symbol | ||
| | |- | ||
| colspan="2" | If the field does not exist, an empty string is returned. | |||
If a field attribute is also specified (e.g. <code>$#table[!FIELDS,$#fieldId,attribute]</code>), then the field's attribute value is returned. E.g. To retrieve the value of the attribute <code>VTABLE</code> for the field <code>value</code> do the following: <code>#vtable := set $#table[!FIELDS,value,VTABLE]</code>. | |||
: | The following attributes can be queried: <code>NAME</code>,<code>TYPE</code>,<code>VISIBLE</code>,<code>SCALE</code>,<code>FORMAT</code>,<code>MMODE</code>,<code>MVALUE</code>,<code>MSYMBOL</code>,<code>HEADER</code>,<code>WIDTH</code>,<code>ALIGN</code>,<code>SORTABLE</code>,<code>EDITABLE</code>,<code>VTABLE</code>,<code>VFIELD</code>,<code>VONLY</code>,<code>VDEFAULT</code>,<code>VUSERDEFAULT</code>,<code>INDEX</code> | ||
|- | |||
| <var>!HASFIELD</var> | |||
| colspan="2" | <code>$#table[!hasfield,hugo]</code> evaluates to 1 in case of table <var>#table</var> having a field (i.e. column) called "hugo" (for arbitrary values of "hugo"). It evaluates to 0 otherwise. | |||
If you do not supply a <code>hugo</code>, the expression will evaluate to 1 if the table has at least one column. If the table is completely devoid of columns, the expression evaluates to zero. | |||
|- | |||
| <var>!ICOLUNDEFINED</var> | |||
| colspan="2" | currently undocumented | |||
|- | |||
| rowspan="2" | <var>!INTFORMAT</var> | |||
| colspan="2" | C format string for integer fields. Must be a valid format for one integer number. | |||
|- | |||
| Note: | |||
| the values of the attributes <code>!IO</code>, <code>!LSEP</code>, <code>!VSEP</code>, <code>!NUMFORMAT</code> and <code>!INTFORMAT</code> may be modified with the command <code>[[Programmer_Guide/Shell_Items/Table/SET_TABLE#FORMAT|SET table FORMAT]]</code>. | |||
|- | |- | ||
| rowspan="4" | <var>!IO</var> | |||
| colspan="2" | The index of selected I/O format (0 or 1): | |||
|- | |||
|0 | |0 | ||
|all fields of an entry are stored; fields are separated by the list | |all fields of an entry are stored; fields are separated by the list separator (!LSEP) | ||
|- | |- | ||
|1 | |1 | ||
|the index and the value of assigned fields are stored; index and value are separated by the value<nowiki>-</nowiki>separator (!VSEP) and fields are separated by the list-separator (!LSEP). | |the index and the value of assigned fields are stored; index and value are separated by the value<nowiki>-</nowiki>separator (!VSEP) and fields are separated by the list-separator (!LSEP). | ||
|- | |||
| Note: | |||
| the values of the attributes <code>!IO</code>, <code>!LSEP</code>, <code>!VSEP</code>, <code>!NUMFORMAT</code> and <code>!INTFORMAT</code> may be modified with the command <code>[[Programmer_Guide/Shell_Items/Table/SET_TABLE#FORMAT|SET table FORMAT]]</code>. | |||
|- | |||
| rowspan="2" | <var>!LSEP</var> | |||
| colspan="2" | the list separator string, used to separates, as its name implies, fields | |||
|- | |||
| Note: | |||
| the values of the attributes <code>!IO</code>, <code>!LSEP</code>, <code>!VSEP</code>, <code>!NUMFORMAT</code> and <code>!INTFORMAT</code> may be modified with the command <code>[[Programmer_Guide/Shell_Items/Table/SET_TABLE#FORMAT|SET table FORMAT]]</code>. | |||
|- | |||
|- | |||
| <var>!MEMORY</var> | |||
| colspan="2" | returns the size of the pre-allocated memory in bytes and the amount of memory currently being used in bytes in the format <code>reserved used</code>. | |||
This attribute is currently supported by extended, and parameter tables only (-1 is returned for other table types). | |||
|- | |||
| <var>!NCOL</var> | |||
| colspan="2" | the number of columns. | |||
|- | |||
| <var>!NCOLUNDEFINED</var> | |||
| colspan="2" | the number of undefined columns. | |||
|- | |||
| <var>!NROW</var> | |||
| colspan="2" | the number of rows (note that this is the same as the <code>!FIELDS</code> attribute). | |||
|- | |||
| rowspan="2" | <var>!NUMFORMAT</var> | |||
| colspan="2" | the C format string for numeric fields. This must be a valid format for one float number. | |||
|- | |||
| Note: | |||
| the values of the attributes <code>!IO</code>, <code>!LSEP</code>, <code>!VSEP</code>, <code>!NUMFORMAT</code> and <code>!INTFORMAT</code> may be modified with the command <code>[[Programmer_Guide/Shell_Items/Table/SET_TABLE#FORMAT|SET table FORMAT]]</code>. | |||
|- | |||
| rowspan="2" | <var>!PARAMETER</var> | |||
| 1 | |||
| if the table is a parameter table | |||
|- | |||
| 0 | |||
| otherwise | |||
|- | |||
| rowspan="2" | <var>!RANGED</var> | |||
| 1 | |||
| if only tagged entries are visible | |||
|- | |||
| 0 | |||
| if all entries are visible | |||
|- | |||
| <var>!SHELL</var> | |||
| colspan="2" | ID of the shell creating the table item (8 digit hexadecimal number) | |||
|- | |||
| rowspan="7" | <var>!SORT</var> | |||
| colspan="2" | The table sort mode in the following format: | |||
C F<sub>1</sub> O<sub>1</sub> F<sub>2</sub> O<sub>2</sub> F<sub>3</sub> O<sub>3</sub>… | |||
|- | |||
| <code>C</code> | |||
| is 0 or 1, indicating whether sorting is case-insensitive (0), or case-sensitive (1) | |||
|- | |||
| <code>F<sub>1</sub></code> | |||
| the field number of the primary sort field (the primary key) | |||
|- | |||
| <code>O<sub>1</sub></code> | |||
| indicates the sort order for the primary key, 0 indicating ascending order, and 1 indicating descending order | |||
|- | |||
| rowspan="2" | <code>F<sub>2</sub> O<sub>2</sub></code> | |||
| are the field number, and the sort order for the secondary key, and so on. | |||
|- | |||
| There will be as many <code>F<sub>n</sub> O<sub>n</sub></code> pairs as there are sort keys. | |||
|- | |||
| colspan="2" | If the table is unsorted, the <code>!SORT</code> attribute will be empty which, when you think about it, seems quite the right thing for it to be in this case. | |||
|- | |||
| <var>!STARTZ</var> | |||
| colspan="2" | The number of entries allocated on initialization. This is the value passed to the <code>/I=''n''</code> option of the <code>NEW table</code> command. | |||
|- | |||
| <var>!TAGGED</var> | |||
| colspan="2" | The number of tagged entries. | |||
|- | |||
| <var>!USERS</var> | |||
| colspan="2" | number of linked items using the respective table item. | |||
|- | |||
| rowspan="2" | <var>!VSEP</var> | |||
| colspan="2" | The value-separator string, used to separate the field name from the field value. | |||
|- | |||
| Note: | |||
| the values of the attributes <code>!IO</code>, <code>!LSEP</code>, <code>!VSEP</code>, <code>!NUMFORMAT</code> and <code>!INTFORMAT</code> may be modified with the command <code>[[Programmer_Guide/Shell_Items/Table/SET_TABLE#FORMAT|SET table FORMAT]]</code>. | |||
|} | |} | ||
Latest revision as of 08:21, 7 December 2016
Table Item | |||
---|---|---|---|
INTRODUCTION | NEW | SET | ATTRIBUTES |
Table attributes
Generally, table attributes, and table entries, are retrieved in the following way:
#target := $#table[…]
Overview
$#table[!ATTRIBUTE]
|
retrieves the respective attribute ATTRIBUTE; see below for the list of available attributes. |
$#table[]
|
retrieves the number of entries in a table (bluntly put: its size) |
$#table[$#index, $#fieldid]
|
This expression will return the value of field fieldid (named by its index, or by its name) of entry index (a number in the range 0…$#table[]-1 ).
|
$#table[$#index, !TAGGED]
|
this expression evaluates to 1 if entry index is tagged, and to 0 otherwise. |
$#table[$#index]
|
For a simple table, this expression returns the entry at the respective index. For extended tables, the return value depends on the mode: for extended tables in data-access mode, the value of all fields of the respective entry are returned, the result depending on the selected format (SHOW or WRITE ); for extended tables in configuration mode, the expression will return the configuration of the field referenced by index (index being the numerical index, or the name, of the desired field). The format of the result is the same as for attribute !FIELD .
|
List of attributes
Attribute | Value(s) and Description | |
---|---|---|
!CHUNKSZ | The number of entries per memory chunk used for growing the table when the allocated memory runs out. This is the value passed to NEW table with the option /N=m .
| |
!DIRECTORY | 1 |
if table is a segment directory |
0 |
otherwise | |
!EDITABLE | The item attribute !EDITABLE indicates whether the respective field (column) of the table is editable when the table is connected to an STx dialog item listview control. You may both query the !EDITABLE attribute, and assign to it. By assigning to the !EDITABLE attribute of a column, you may at any time specify if the respective column may be edited by the user: Assigning 0 prevents editing, whereas any numeric value different from 0 allows for editing.
The E.g. An optional third argument can be used to specify number of fields to set (if omitted, just the one field Examples: // query if the 3rd column of table #tab is editable #txt := COND $#tab[!edit,2] == 0 ? 'is NOT' : 'IS' um 'Column 2 (i.e. 3rd column) $#txt editable.' // allow for the 3rd column (index 2) of table #tab to be edited $#tab[!edit,2] := 1 // prevent its first column (index 0) from being edited $#tab[!edit,0] := 0 // set the 2nd and 3rd columns to editable $#tab[!edit,1,2] := 1 Also see the example script | |
!EXTENDED | 1 |
if table is an extended table |
0 |
otherwise | |
!FIELDS | The !FIELDS attribute returns the number of defined fields (note that this is the same as !NCOL ).
If specified with a field name or index (e.g. | |
type | numeric type id (0=undefined, 1=NAME, 2=STRING, 3=INTEGER, 4=NUMBER) | |
name
|
field name | |
show
|
1 if field is included in show format | |
showname
|
1 if name is included in show format | |
scale
|
show scaling factor for numeric types | |
format
|
format string used for show | |
mvalue,
|
missing value and symbol | |
If the field does not exist, an empty string is returned.
If a field attribute is also specified (e.g. The following attributes can be queried: | ||
!HASFIELD | $#table[!hasfield,hugo] evaluates to 1 in case of table #table having a field (i.e. column) called "hugo" (for arbitrary values of "hugo"). It evaluates to 0 otherwise.
If you do not supply a | |
!ICOLUNDEFINED | currently undocumented | |
!INTFORMAT | C format string for integer fields. Must be a valid format for one integer number. | |
Note: | the values of the attributes !IO , !LSEP , !VSEP , !NUMFORMAT and !INTFORMAT may be modified with the command SET table FORMAT .
| |
!IO | The index of selected I/O format (0 or 1): | |
0 | all fields of an entry are stored; fields are separated by the list separator (!LSEP) | |
1 | the index and the value of assigned fields are stored; index and value are separated by the value-separator (!VSEP) and fields are separated by the list-separator (!LSEP). | |
Note: | the values of the attributes !IO , !LSEP , !VSEP , !NUMFORMAT and !INTFORMAT may be modified with the command SET table FORMAT .
| |
!LSEP | the list separator string, used to separates, as its name implies, fields | |
Note: | the values of the attributes !IO , !LSEP , !VSEP , !NUMFORMAT and !INTFORMAT may be modified with the command SET table FORMAT .
| |
!MEMORY | returns the size of the pre-allocated memory in bytes and the amount of memory currently being used in bytes in the format reserved used .
This attribute is currently supported by extended, and parameter tables only (-1 is returned for other table types). | |
!NCOL | the number of columns. | |
!NCOLUNDEFINED | the number of undefined columns. | |
!NROW | the number of rows (note that this is the same as the !FIELDS attribute).
| |
!NUMFORMAT | the C format string for numeric fields. This must be a valid format for one float number. | |
Note: | the values of the attributes !IO , !LSEP , !VSEP , !NUMFORMAT and !INTFORMAT may be modified with the command SET table FORMAT .
| |
!PARAMETER | 1 | if the table is a parameter table |
0 | otherwise | |
!RANGED | 1 | if only tagged entries are visible |
0 | if all entries are visible | |
!SHELL | ID of the shell creating the table item (8 digit hexadecimal number) | |
!SORT | The table sort mode in the following format:
C F1 O1 F2 O2 F3 O3… | |
C
|
is 0 or 1, indicating whether sorting is case-insensitive (0), or case-sensitive (1) | |
F1
|
the field number of the primary sort field (the primary key) | |
O1
|
indicates the sort order for the primary key, 0 indicating ascending order, and 1 indicating descending order | |
F2 O2
|
are the field number, and the sort order for the secondary key, and so on. | |
There will be as many Fn On pairs as there are sort keys.
| ||
If the table is unsorted, the !SORT attribute will be empty which, when you think about it, seems quite the right thing for it to be in this case.
| ||
!STARTZ | The number of entries allocated on initialization. This is the value passed to the /I=n option of the NEW table command.
| |
!TAGGED | The number of tagged entries. | |
!USERS | number of linked items using the respective table item. | |
!VSEP | The value-separator string, used to separate the field name from the field value. | |
Note: | the values of the attributes !IO , !LSEP , !VSEP , !NUMFORMAT and !INTFORMAT may be modified with the command SET table FORMAT .
|