Programmer Guide/Shell Items/Table/SET TABLE: Difference between revisions

From STX Wiki
Jump to navigationJump to search
 
(62 intermediate revisions by 5 users not shown)
Line 1: Line 1:
{{DISPLAYTITLE:{{SUBPAGENAME}}}}
{{DISPLAYTITLE:{{SUBPAGENAME}}}}
 
{{Table_Item_Template}}
The <code>SET <var>table</var>&hellip;</code> command is used to modify a table item. The sub-commands documented here are valid for all table types, unless otherwise specified.
The <code>SET <var>table</var>&hellip;</code> command is used to modify a table item. The sub-commands documented here are valid for all table types, unless otherwise specified.


== Adding table entries ==
== Setting or Adding table entries ==


  SET <var>table</var> <var>index</var>|* &hellip; [ /Tag | /Untag ]
  SET <var>table</var> <var>index</var>|* &hellip; [ /Tag | /Untag ]


When using the index of an existing entry for <var>index</var>, the command will modify the respective entry. When supplying the asterisk, &quot;<code>*</code>&quot;, for <var>index</var>, a new entry will be appended to the end of the table. Finally, when supplying a value for <var>index</var> that is ''greater'' than the number of entries (<var>table</var><code>[]</code>), the table will be padded with an appropriate number of empty entries in order to allow the entry <var>index</var> to be set.
When using the index of an ''existing'' entry for <var>index</var>, the command will modify the respective entry. When supplying the asterisk, &quot;<code>*</code>&quot;, for <var>index</var>, a ''new entry'' will be appended to the end of the table. Finally, when supplying a value for <var>index</var> that is ''greater'' than the number of entries (<var>table</var><code>[]</code>), the table will be padded with an appropriate number of empty entries in order to allow the entry <var>index</var> to be set.


The options <code>/Tag</code> and <code>/Untag</code> may be used for setting or clearing the tag flag.
The options <code>/Tag</code> and <code>/Untag</code> may be used for setting or clearing the tag flag.
Line 25: Line 25:
| <var>entryValue</var>
| <var>entryValue</var>
| The value to assign to the entry.
| The value to assign to the entry.
|-
| <code>/Tag</code> or <code>/Untag</code>
| tag, or untag, the respective entry
|}
|}


Line 37: Line 40:
| The zero-based index of an existing entry to modify the entry's data or a zero-based index greater than the number of existing entries, to add a new entry. If the index is greater than the total number of entries, then all missing entries are created and initialized with default values. An asterisk may be used to append the table with a new entry at the next free index.
| The zero-based index of an existing entry to modify the entry's data or a zero-based index greater than the number of existing entries, to add a new entry. If the index is greater than the total number of entries, then all missing entries are created and initialized with default values. An asterisk may be used to append the table with a new entry at the next free index.
|-
|-
| <var>fieldId</var>
| <var>fieldId<sub>1</sub></var>&hellip;
| A valid field id (as defined in the <code>[[User Guide/Workspace/Spectrum Viewer pre-configured profiles|NEW TABLE]]</code> command) or a field index.
| A valid field id (as defined in the <code>[[User Guide/Workspace/Spectrum Viewer pre-configured profiles|NEW TABLE]]</code> command) or a field index.
|-
|-
| <var>fieldValue</var>
| <var>fieldValue<sub>1</sub></var>&hellip;
| The value to assign to the respective field.
| The value to assign to the respective field.
|-
|-
Line 47: Line 50:
|-
|-
| <code>/N=<var>n</var></code>
| <code>/N=<var>n</var></code>
| Repeat this assignment for the next <var>n</var> entries (with <code>/N=<var>n</var></code>), or for ''all'' entries from the current one to the last one (with <code>/N=all</code>), or for all tagged entries from the current one to the last one (<code>/N=tagged</code>). Note that the <code>all</code> and <code>tagged</code> variants cannot append new entries to the table.
| Repeat this assignment for the next <var>n</var> entries (with <code>/N=<var>n</var></code> and <var>n</var> being an integer higher than, or equal to, 1), or for ''all'' entries from the current one to the last one (with <code>/N=all</code>), or for all tagged entries from the current one to the last one (<code>/N=tagged</code>). Note that the <code>all</code> and <code>tagged</code> variants cannot append new entries to the table. Note also that you cannot set 'all' entries, if only tagged entries are currently visible.
|}
|}


Line 53: Line 56:
  $#extTable 0 0 0 /N=10
  $#extTable 0 0 0 /N=10


== Configuring a table field==
== Retrieving a table entry ==


This command is only applicable to extended tables
You can retrieve a table entry using the following syntax: <code>$#table[$#index]</code>. If the table has columns defined, you can use the syntax <samp>$#table[$#index,$#columnid]</samp>.


=== CONFIG ===
== Configuring a table field==


<code>SET <var>table</var> CONFIG <var>fieldid</var> [ <var>show name scale format mmode mval msym header width align sort</var> <var>editable</var> [ <var>listtable</var> <var>listfield</var> <var>listonly</var> <var>setdefault</var> <var>setuserdefault</var> <var>multirow</var> ]]</code>
The <code>SET table CONFIG</code> command is only applicable to [[Programmer_Guide/Concepts/Extended_table|extended tables]] (after all, [[Programmer_Guide/Concepts/Simple_table|simple tables]] do not have fields).


Configure a table field. Define the display format (list box and list view) and field properties. The field must have been specified in the <code>[[User Guide/Workspace/Spectrum Viewer pre-configured profiles|NEW TABLE]]</code> command. The table must be in configuration mode (see <code>MODE</code>).
SET <var>table</var> CONFIG <var>fieldid</var> [ <var>show</var> <var>name</var> <var>scale</var> <var>format</var> <var>mmode</var> <var>mval</var> <var>msym</var> <var>header</var> <var>width</var> <var>align</var> <var>sort</var> <var>editable</var>
                          [ <var>listtable</var> <var>listfield</var> <var>listonly</var> <var>setdefault</var> <var>setuserdefault</var> <var>multirow</var> ] ]


;<var>fieldid</var>
Configure a table field. Define the display format (list box and list view) and field properties. The field must have been specified in the <code>[[Programmer_Guide/Shell_Items/Table/NEW_TABLE|NEW TABLE]]</code> command. The table must be in configuration mode (see <code>[[#Setting_the_table_mode|MODE]]</code>).


:The name or index of the field to be configured / updated.
{|class="keinrahmen"
| <var>fieldid</var>
| The name or index of the field to be configured / updated.
|-
| <var>show</var>
| Show (<code>1</code> or <code>ON</code>) or hide (<code>0</code> or <code>OFF</code>) the field in listbox and list view controls
|-
| <var>name</var>
| Show both name and value (<code>1</code> or <code>ON</code>) or value only (<code>0</code> or <code>OFF</code>) in list box controls. This is only effective if <var>show</var> is <code>ON</code>.
|-
| <var>scale</var>
| The scaling factor for numeric fields; if a numeric field is accessed in the [[Programmer_Guide/Shell_Items/Table/Introducing_Table_Items#The_Show_Format|show format]], its value is multiplied with scale (used by both listboxes and listviews).
|-
| <var>format</var>
| The [[Programmer Guide/Shell Items/Table/Show_Format|show format]] format string.


;<var>show</var>
For fields of type <code>NAME</code> or <code>STRING</code>, the format must contain a string tag (e.g.: <code>%s</code>, <code>%10.10s</code>) For both numeric field types (<code>INTEGER</code> and <code>NUMBER</code>), the format must contain a float tag (<code>%f</code>, <code>%g</code>). The float tag is necessary for integer values because the scaling factor (<var>scale</var>) is a floating number.


:Show (<code>1</code>|<code>ON</code>) or hide (<code>0</code>|<code>OFF</code>) field in listbox and list view controls
Note that to display an integer (without decimals) you can use the format tag <code>%5.0f</code>. This parameter controls the format for listboxes and listviews dialog controls.
 
|-
;<var>name</var>
| <var>mmode</var>
 
| Enable (<code>1</code>|<code>ON</code>) or disable (<code>0</code>|<code>OFF</code>) missing value replacement. Missing value replacement is disabled by default. If enabled, missing values are replaced by <var>msym</var>.
:Show name and value (<code>1</code>|<code>ON</code>) or only value (<code>0</code>|<code>OFF</code>) in list box controls. Only active if <var>show</var> is <code>ON</code>.
|-
 
| <var>mval</var>
;<var>scale</var>
| The numeric id value of a 'missing value' (e.g. <code>0</code> for f0 data). The default is <code>0</code>. Missing value replacement only works for numerical fields (<code>NUMBER</code> or <code>INTEGER</code>).
 
|-
:The scaling factor for numeric fields; if a numeric field is accessed in the show format, its value is multiplied with scale (used by both listboxes and listviews).
| <var>msym</var>
 
| The replacement symbol (string) for missing values (e.g. <code>UNVOICED</code> for f0 data). The strings <code><empty></code> and <code><blank></code> can be used to replace a missing value with an empty string or a blank character. The default string is the empty string.
;<var>format</var>
|-
 
| <var>header</var>
:The show format format string.
| The text to be displayed in the field's column header of a listview control.
 
|-
:For fields of type <code>NAME</code> or <code>STRING</code>, the format must contain a string tag (e.g.: <code>%s</code>, <code>%10.10s</code>, ..) For both numeric field types (<code>INTEGER</code> and <code>NUMBER</code>), the format must contain a float tag (<code>%f</code>, <code>%g</code>). The float tag is necessary for integer values because the scaling factor (<var>scale</var>) is a floating number.
| <var>width</var>
 
| The width (in characters) of the column of a listview control.
:Note that to display an integer (without decimals) you can use the format tag <code>%5.0f</code>. This parameter controls the format for listboxes and listviews dialog controls.
|-
 
| <var>align</var>
;<var>mmode</var>
| Align field left (<code>0</code>) or right (<code>1</code>) in the column of a listview control; The first column of a listview is always. left-aligned (align is ignored)
 
|-
:Enable (<code>1</code>|<code>ON</code>) or disable (<code>0</code>|<code>OFF</code>) missing value replacement. Missing value replacement is disabled by default. If enabled, missing values are replaced by <var>msym</var>.
| <var>sort</var>
 
| Enable (<code>1</code>) or disable (<code>0</code>) the sort function of the column header of a listview control.
;<var>mval</var>
|-
 
| <var>editable</var>
:The numeric id value of a 'missing value' (e.g. <code>0</code> for f0 data). The default is <code>0</code>. Missing value replacement only works for numerical fields (<code>NUMBER</code> or <code>INTEGER</code>).
| If <var>editable</var> is set to <code>0</code>, the respective field (column) of the table is NOT editable when the table is connected to a <code>ListView</code> item. If <var>editable</var> is set to a number different from <code>0</code>, the respective field (column) of the table IS editable when the table is connected to a <code>ListView</code> item. See the example script <code>editabletable.sts</code> for a complete example.
 
|-
;<var>msym</var>
| <var>listtable</var>
 
| The name of a table containing all permissible values for this field. If this table (<var>table</var>) is connected to a <code>listview</code> item, and the <var>listtable</var> parameter is specified, the <code>listview</code> displays a combobox in the associated column, and fills the combobox with <var>listtable</var>'s values.
:The replacement symbol (string) for missing values (e.g. <code>UNVOICED</code> for f0 data). The strings <code><empty></code> and <code><blank></code> can be used to replace a missing value with an empty string or a blank character. The default string is the empty string.
|-
 
| <var>listfield</var>
;<var>header</var>
| The field id specifying the field in <var>listtable</var> where the values are stored. If <var>listtable</var> is a simple table, <var>listfield</var> must be <code>0</code>.
 
|-
:The text to be displayed in the field's column header of a listview control.
| <var>listonly</var>
 
| The <var>listonly</var> parameter specifies whether this <var>table</var>'s field may only use values in the list table (<code>1</code>), or whether any values may be entered (<code>0</code>). If <code>0</code>, then the combobox is editable.
;<var>width</var>
|-
 
| <var>setdefault</var>
:The width (in characters) of the column of a listview control.
| The <var>setdefault</var> parameter specifies whether invalid or empty data entered whilst editing should be replaced by the default value (<code>1</code>=yes, <code>0</code>=no). The first value in the list table is the default value.
 
|-
;<var>align</var>
| <var>setuserdefault</var>
 
| If set to <code>ON</code> or <code>1</code>, the last user-input for this field will be used as the respective default value.
:Align field left (<code>0</code>) or right (<code>1</code>) in the column of a listview control; The first column of a listview is always. left-aligned (align is ignored)
|-
 
| <var>multirow</var>
;<var>sort</var>
| If set to <code>1</code> or <code>ON</code>, the field can display text in multiple rows. If set to <code>0</code> or <code>OFF</code>, text will be displayed in one row. The default is <code>OFF</code>.
 
|}
:Enable (<code>1</code>) or disable (<code>0</code>) the sort function of the column header of a listview control.
 
;<var>editable</var>
 
:If <var>editable</var> is set to <code>0</code>, the respective field (column) of the table is NOT editable when the table is connected to a <code>ListView</code> item. If <var>editable</var> is set to a number different from <code>0</code>, the respective field (column) of the table IS editable when the table is connected to a <code>ListView</code> item. See the example script <code>editabletable.sts</code> for a complete example.
 
;<var>listtable</var>
 
:The name of a table containing all permissible values for this field. If this table (<var>table</var>) is connected to a <code>listview</code> item, and the <var>listtable</var> parameter is specified, the <code>listview</code> displays a combobox in the associated column, and fills the combobox with <var>listtable</var>'s values.
 
;<var>listfield</var>
 
:The field id specifying the field in <var>listtable</var> where the values are stored. If <var>listtable</var> is a simple table, <var>listfield</var> must be <code>0</code>.
 
;<var>listonly</var>
 
:The <var>listonly</var> parameter specifies whether this <var>table</var>'s field may only use values in the list table (<code>1</code>), or whether any values may be entered (<code>0</code>). If <code>0</code>, then the combobox is editable.
 
;<var>setdefault</var>
 
:The <var>setdefault</var> parameter specifies whether invalid or empty data entered whilst editing should be replaced by the default value (<code>1</code>=yes, <code>0</code>=no). The first value in the list table is the default value.
 
;<var>setuserdefault</var>
 
:If set to <code>ON</code> or <code>1</code>, the last user-input for this field will be used as the respective default value.
 
;<var>multirow</var>
 
:If set to <code>1</code> or <code>ON</code>, the field can display text in multiple rows. If set to <code>0</code> or <code>OFF</code>, text will be displayed in one row. The default is <code>OFF</code>.
 
:


A field is defined once, but can be configured as often as needed. If an argument is not supplied or set to '<code>*</code>', the configuration for that parameter is not changed.See the example script <code>editabletable.sts</code> for a detailed example.
A field is defined once, but can be configured as often as needed. If an argument is not supplied or set to '<code>*</code>', the configuration for that parameter is not changed.See the example script <code>editabletable.sts</code> for a detailed example.


== Copying table entries ==
== Table-to-table Copy ==
 
There are three ways to copy the contents of one table to another. The first is when creating a table (<code>#t := new table * $#baseTable /Copy /All</code>), the second if using the following syntax: <code>$#table1 := $#table2</code>, and the third is the following command:
 
=== COPY ===
 
<code>SET <var>table</var> COPY <var>srctable</var> [<var>fieldid</var> ... ] [ /Rows /Columns ]</code>
 
Copy data between two tables - the source table (<var>srcTable</var>) and the target table (<var>table</var>). If fields (<var>fieldids</var>) are specified, then only these fields are copied. Otherwise all of the source table's fields are copied. If the command is called without options (/R|C), then the source table must have the same fields as the target table and the source entries overwrite the target entries (appending entries if necessary).
 
The options /Rows and /Columns do not overwrite existing entries and fields in the target table. Rather they modify the table, appending source fields (which do not exist in the target table) and entries to the target table. Note that the target table must have enough undefined fields to accommodate the appended fields (i.e. fields created by [[User Guide/Workspace/Spectrum Viewer pre-configured profiles|NEW TABLE]] but not defined yet).
 
Note that both tables must be extended or parameter tables.;<var>srctable</var>
 
:The id of source table to copy from. This must be an extended or parameter table.
 
;<var>fieldid</var>
 
:A blank separated list of field ids. If specified, these fields are copied, otherwise all fields are copied.
 
;<var>/Rows</var>
 
:If specified, entries from <var>srctable</var> are appended to <var>table</var>. The fields being copied must already be defined in <var>table</var>. Note that the field data type is not checked (i.e. number fields can be copied to string fields of the same name).
 
;<var>/Columns</var>
 
:If specified, entries from <var>srctable</var> are copied to the same entries in <var>table</var>. Fields not defined in <var>table</var> are automatically defined and configured. For this reason there must be enough undefined fields in <var>table</var>.
 
<code>SET <var>table</var> COPY <var>outputName i j</var> [ /Row|Col ] [ /Write ]</code>
 
Copy data between a table and a value object. If the option /Write is used, the table data is copied to the value item, otherwise (default) the value item data is copied to the table.
 
;<var>outputName</var>
 
:The name of a value item to copy to or from.
 
;<var>i</var>
 
:The entry index.
 
;<var>j</var>
 
:The field index.
 
;<var>/Row</var>
 
:Copy table fields starting at row <var>i</var> field <var>j</var>. The number of fields copied is determined by the size of the vector. The number of rows copied is determined by the number of vectors (only for array value items). This option is only for array and vector value items.
 
;<var>/Col</var>
 
:Copy table entries starting at row <var>i</var> field <var>j</var>. The number of rows copied is determined by the size of the vector. The number of fields copied is determined by the number of vectors (array value items). This option is only for array and vector value items.


;<var>/Write</var>
SET <var>table</var> COPY <var>srctable</var> [<var>fieldid</var> &hellip; ] [ /Rows /Columns ]


:If the option /Write is specified, the table data is copied to the value item, otherwise (default) the value item data is copied to the table.
Copy data from the source table <var>srcTable</var> (a parameter table or an extended table) to the target table <var>table</var> (a table of the same kind). If fields (<var>fieldids</var>) are specified, then only these fields are copied. Otherwise all fields of the source table are copied.


== Copying to the clipboard ==
If the command is called ''without'' supplying options <code>/Rows</code> or <code>/Columns</code>), then
# the source table must have the ''same format'', i.e. the same fields, as the target table; and
# the source entries will ''overwrite'' the target entries (appending entries if necessary).


=== CLIPBOARD ===
If the command is called with either option <code>/Rows</code> or <code>/Columns</code>, the command will ''not'' overwrite existing entries and fields in the target table. Rather than that, the command will ''modify'' the target table, appending source fields (which do not exist in the target table) and entries to the target table. Note that the target table must have enough undefined fields to accommodate the appended fields (i.e. fields created by <code>[[Programmer_Guide/Shell_Items/Table/NEW_TABLE|NEW TABLE]]</code>, but yet undefined).


<code>SET <var>table</var> CLIPBOARD [ /Show|Write ]</code>
Note that the <code>COPY</code> command works only with extended and with parameter tables.


Copy the visible entries of a table to the clipboard. The entries can be copied in the show-format (/Show; use listbox display format (default)) or in the write-format (/Write; use the format for writing to files). You can specify the write and show format using the <code>SET table CONFIG</code> command.
;<var>srctable</var>:The table to copy from. This must be an extended or parameter table.
;<var>fieldid</var>: An optional list of field IDs, separated by blank. If specified, only these fields are copied. If omitted, all fields are copied.
;<code>/Rows</code>: If specified, fields from <var>srctable</var> are appended to <var>table</var>. The fields being copied must already be defined in <var>table</var>. Note that the field data type is not checked (i.e. number fields can be copied to string fields of the same name).
;<code>/Columns</code>: If specified, entries from <var>srctable</var> are copied to the ''same'' entries in <var>table</var>, ''overwriting their old value''. Fields not defined in <var>table</var> are automatically defined and configured. For this reason there must be enough undefined fields in <var>table</var>.


;<var>/Show</var>
== Copying between a Table and a Value Item ==


:Use the show format to format each entry string. This is the default.
SET <var>table</var> COPY <var>outputName</var> <var>i</var> <var>j</var> [ /Row|Col ] [ /Write ]


;<var>/Write</var>
Copy data between a table and a [[Programmer_Guide/Shell_Items/Value|value object]]. If the option <code>/Write</code> is used, the table data is copied to the value item, otherwise (default) the value item data is copied to the table.


:Use the write format to format each entry string.
;<var>outputName</var>: The name of a value item to copy to or from.
;<var>i</var>: The entry index.
;<var>j</var>: The field index.
;<code>/Row</code>: Copy table fields starting at row <var>i</var> field <var>j</var>. The number of fields copied is determined by the size of the vector. The number of rows copied is determined by the number of vectors (only for array value items). This option is only for array and vector value items.
;<code>/Col</code>: Copy table entries starting at row <var>i</var>, field <var>j</var>. The number of rows copied is determined by the size of the vector. The number of fields copied is determined by the number of vectors (array value items). This option is only for array and vector value items.
;<code>/Write</code>: If the option <code>/Write</code> is specified, the table data is copied to the value item. If omitted, the value item data is copied to the table.


<code>SET <var>table</var> CLIPBOARD /Read [ /Delete ] [ /Empty ]</code>
== Copying to and from the clipboard ==


Read the last entry from the clipboard. Reading is only successful if the format is supported. The formats <code>CF_UNICODETEXT</code> and <code>CF_TEXT</code> are supported.
SET <var>table</var> CLIPBOARD [ /Show|Write ]


;<var>/Read</var>
Copy the visible entries of a table to the clipboard. The entries can be copied either in:
# [[Programmer_Guide/Shell_Items/Table/Introducing_Table_Items#Show_Format|show-format]], i.e. using listbox display format, when supplying the <code>/Show</code> option (or no option at all, since this is the default); or in
# [[Programmer_Guide/Shell_Items/Table/Introducing_Table_Items#Write_Format|write-format]], i.e. the format normally used when writing to a file. This is done with the <code>/Write</code> option.


:Mandatory option.
;<code>/Show</code>: Use the show format to format each entry string. This is the default.
;<code>/Write</code>: Use the write format to format each entry string.


;<var>/Delete</var>
SET <var>table</var> CLIPBOARD /Args arg1 arg2 ... [ /Show|Write ]


:Delete the table entries before reading from the clipboard.
Copy the content of the arguments to the clipboard. Each argument <code>argI</code> can be a string (string is copied) or a table item (content of table is copied). The option <code>/Show|Write</code> specifies the output format used for the table items (as described above). The content of the table item <var>table</var> is only copied, if it is specified as argument.


;<var>/Empty</var>
SET <var>table</var> CLIPBOARD /Read [ /Delete ] [ /Empty ]


:Empty the clipboard after a successful read.
Read the last entry from the clipboard. This will work only if the format of the respective clipboard entry is either Unicode (<code>CF_UNICODETEXT</code>) or text (<code>CF_TEXT</code>).
;<code>/Read</code>: Mandatory option.
;<code>/Delete</code>: Delete the table entries before reading from the clipboard.
;<code>/Empty</code>: Empty the clipboard after a successful read.


== Defining a table field ==
== Defining a table field ==


This command is only applicable to extended tables
SET <var>table</var> DEFINE <var>index</var>|<var>* type name</var> [<var>count offset</var>] [/Auto] [/Undefine]
 
=== DEFINE ===
 
<code>SET <var>table</var> DEFINE <var>index</var>|<var>* type name</var> [<var>count offset</var>] [/Auto] [/Undefine]</code>
 
Note that the table must be in configuration mode (see <code>MODE</code>). Define the data type and name of field <var>index</var> (0 .. number of fields - 1). If an asterisk '<code>*</code>' is given instead of <var>index</var>, the first free (undefined) index is used. The argument <var>type</var> is the id of the data type of the field. The argument <var>name</var> is the name to be assigned to the field and must be a valid name string. The parameters <var>count</var> and <var>offset</var> can be used to define multiple fields with one command (<var>count</var> = number of fields, <var>offset</var> = base index). The option /Auto ensures the name is unique by concatenating the string name with an index (first value: 1). Note that once you have configured the table, you need to switch to DATA mode (see <code>MODE</code> below).
 
;<var>index</var>


:The index of the field to be defined or '*' for the next free index.
Note that the table must be in configuration mode (see [[XXX|<code>MODE</code>]]). Define the data type and name of field <var>index</var> (0 .. number of fields - 1). If an asterisk '<code>*</code>' is given instead of <var>index</var>, the first free (undefined) index is used. The argument <var>type</var> is the id of the data type of the field. The argument <var>name</var> is the name to be assigned to the field and must be a valid name string. The parameters <var>count</var> and <var>offset</var> can be used to define multiple fields with one command (<var>count</var> = number of fields, <var>offset</var> = base index). The option /Auto ensures the name is unique by concatenating the string name with an index (first value: 1). Note that once you have configured the table, you need to switch to DATA mode (see [[XXX|<code>MODE</code>]] below).


;<var>type</var>
The <code>SET <var>table</var> DEFINE</code> command is only applicable to [[Programmer_Guide/Concepts/Extended_table|extended tables]], since only they support different types of fields.
 
:The type of data to be stored. The following values are supported:


;<var>index</var>: The index of the field to be defined or '*' for the next free index.
;<var>type</var>: The type of data to be stored. The following values are supported:
:<code>NAME</code> - Strings which are valid names.
:<code>NAME</code> - Strings which are valid names.
:<code>STRING</code> - Free text.
:<code>STRING</code> - Free text.
:<code>INTEGER</code> - Integer numbers.
:<code>INTEGER</code> - Integer numbers.
:<code>NUMBER</code> - Floating point numbers.
:<code>NUMBER</code> - Floating point numbers.
;<var>name</var>: The name to assign to the field. Note that this must also be a valid name.
;<var>count</var>: The number of fields to define. Used in conjunction with <var>offset</var> for multiple definitions. Must be >= <code>1</code>.
;<var>offset</var>: The index to start multiple definitions with. Must be >= <code>0</code>.


;<var>name</var>
== Undefining a table field ==
 
:The name to assign to the field. Note that this must also be a valid name.
 
;<var>count</var>


:The number of fields to define. Used in conjunction with <var>offset</var> for multiple definitions. Must be >= <code>1</code>.
SET <var>table</var> DEFINE <var>index</var>|<var>name</var> [&hellip; /Undefine]


;<var>offset</var>
Undefine an existing field and delete contents of all field entries. Multiple undefines are possible by using the option <code>/Undefine</code> in conjunction with multiple parameters.


:The index to start multiple definitions with. Must be >= <code>0</code>.
;<var>index|name</var>: The index or name of the field(s) to undefine.


<code>SET <var>table</var> DEFINE <var>index</var>|<var>name</var> [... /Undefine]</code>
== Renaming a table field ==


Undefine an existing field and delete contents of all field entries. If the option /Undefine is used in conjunction with multiple parameters, multiple undefines are possible.
SET <var>table</var> DEFINE <var>fieldName</var> <var>newName</var> /Rename
 
;<var>index|name</var>
 
:The index or name of the field(s) to undefine.
 
<code>SET <var>table</var> DEFINE <var>fieldName</var> <var>newName</var> /R</code>


Rename an existing field.
Rename an existing field.


;<var>fieldName</var>
;<var>fieldName</var>: The existing field name.
 
;<var>newName</var>: The new field name
:The existing field name.
;<code>/R</code>
 
:The mandatory option <code>/Rename</code>, specifying that this <code>DEFINE</code> command should rename the field.
;<var>newName</var>
 
:The new field name
 
;<var>/R</var>
 
:The mandatory option /R, specifying that this <code>DEFINE</code> command should rename the field.


An example can be found in the macro file <code>table_redefine.sts</code>.
An example can be found in the macro file <code>table_redefine.sts</code>.
Line 305: Line 233:
Delete all visible entries or the specified entry <var>index</var>.
Delete all visible entries or the specified entry <var>index</var>.


== Finding table entries ==
== {{anchor|FIND|Finding table entries}} ==


The <code>FIND</code> function implements a simple 'database query' interface for tables. To create complex queries, it may be necessary to apply a set of <code>FIND</code>s and possibly combine them with the <code>FIND</code> command. The <code>FIND</code> command only searches tagged entries. Therefore, if you want to search the whole table, you must tag all the entries first. At the end of a query (any number of <code>FIND</code> commands), the tagged entries are those matching the <code>FIND</code> criteria.
The <code>FIND</code> function implements a simple 'database query' interface for tables. To create complex queries, it may be necessary to apply a set of <code>FIND</code>s and possibly combine them with the <code>[[Programmer_Guide/Command_Reference/FIND|FIND]]</code> command. The <code>FIND</code> function only searches tagged entries. Therefore, if you want to search the whole table, you must tag all the entries first. At the end of a query (any number of <code>FIND</code> function calls), the tagged entries are those matching the search criteria.


=== FIND ===
SET <var>table</var> FIND
 
<code>SET <var>table</var> FIND</code>


Initialize a new find cycle. The tag flag of all entries are set and visibility is set to ALL. This command should be issued before a new query consisting of multiple commands is started. Instead of this command the option /Start can be used with the (first) <code>FIND</code>.
Initialize a new find cycle. The tag flag of all entries are set and visibility is set to ALL. This command should be issued before a new query consisting of multiple commands is started. Instead of this command the option /Start can be used with the (first) <code>FIND</code>.
Line 327: Line 253:
:The logical operator combining two search criteria; logical operators are applied from left to right, bracketing is not possible. The following operators are supported:
:The logical operator combining two search criteria; logical operators are applied from left to right, bracketing is not possible. The following operators are supported:


:<code>AND</code> - conjunction
::conjunction: <code>AND</code> or <code>&&</code>  
<code>&&</code> - conjunction
::disjunction: <code>OR</code> or <code>||</code>
<code>OR</code> - disjunction
::exclusive disjunction: <code>XOR</code> or <code>^^</code>
<code>||</code> - disjunction
<code>XOR</code> - exclusive disjunction
 
:<code>^^</code> - exclusive disjunction


;<var>/Start</var>
;<var>/Start</var>
Line 353: Line 275:
</pre>
</pre>


=== Find expressions ===
== {{Anchor|FINDEXPR|Find expressions}} ==
 
{{:Programmer_Guide/General_Descriptions/Find_Expressions}}
{|
|-
|<var>cexpr</var>
|Description
|-
|fieldid:cond
|Check if a value is (not) assigned to a field.{|
|-
|fieldid
|name or index of a defined field
|-
|cond
|= (is assigned), ! (is not assigned)
|}
 
 
|-
|fieldid:cond:value
|Check the value of a numerical field (type <code>INTEGER</code> or <code>NUMBER</code>) or find an absolute string match (type STRING for <code>==</code> and <code>!=</code>).{|
|-
|fieldid
|name or index of a numerical field (<code>0</code> for simple tables)
|-
|cond
|<code><</code>, <code><=</code>, <code>==</code>, <code>!=</code>, <code>>=</code> or <code>></code>
|-
|value
|a number, or numerical expression or string.
|}


 
== Regular expressions ==
|-
|fieldid:cond:mask
|Match the value of a string field (type <code>NAME</code> or <code>STRING</code>).{|
|-
|
|
|
|-
|fieldid
|name or index of a string field (<code>0</code> for simple tables)
|-
|cond
|=I
|match, ignore case
|-
|
|!I
|do not match, ignore case
|-
|
|=R
|match respect case
|-
|
|!R
|(do not match, respect case)
|-
|mask
|match string, may contain wildcard characters. if field is of type name, mask must be a valid name
|}
 
|}
 
 
 
==== Regular expressions ====


S_TOOLS<nowiki>-</nowiki>STx supports searches using POSIX regular expression. When using regular expressions, characters which have a special meaning in {{STX}} will need to be escaped using the {{STX}} escape character "<code>`</code>".
S_TOOLS<nowiki>-</nowiki>STx supports searches using POSIX regular expression. When using regular expressions, characters which have a special meaning in {{STX}} will need to be escaped using the {{STX}} escape character "<code>`</code>".
Line 456: Line 312:
|regex
|regex
|a POSIX regular expression.
|a POSIX regular expression.
|}
|}
|}


Line 465: Line 318:
== Formatting table fields ==
== Formatting table fields ==


This command is only applicable to extended tables
Formatting is only applicable to [[Programmer_Guide/Concepts/Extended_table|extended tables]].


=== FORMAT ===
SET <var>table</var> FORMAT <var>format</var> [<var>listdel</var> <var>vardel</var> <var>numfmt </var> <var>intfmt</var>]


<code>SET <var>table</var> FORMAT <var>format</var> [<var>listdel vardel numfmt intfmt</var>]</code>
Configuration of the write format used to save and load tables from files (see [[XXX|<code>SET file LOAD</code>]] and [[XXX|<code>SET file SAVE</code>]]). You can configure the [[Programmer_Guide/Shell_Items/Table/Introducing_Table_Items#The_Show_Format|show format]] (used to display tables in the GUI) using the [[Programmer_Guide/Shell_Items/Table/SET_TABLE#Configuring_a_table_field|<code>CONFIG</code>]] command.
 
Configuration of the write format used to save and load tables from files (see <code>SET file LOAD</code> and <code>SET file SAVE</code>). You can configure the show format (used to display tables in the GUI) using the <code>CONFIG</code> command.


;<var>format</var>
;<var>format</var>
:<code>0</code> - Store all fields even if they are empty. Assigned fields have the format <code>fieldvalue</code> <var>listdel</var> and empty fields have just the <var>listdel</var>. E.g.: <code>10.0 ; 10.1 ; ; 10.3</code>


:<code>0 -</code> Store all fields even if they are empty. Assigned fields have the format <code>fieldvalue</code> <var>listdel</var> and empty fields have just the <var>listdel</var>. E.g.: <code>10.0 ; 10.1 ; ; 10.3</code>
:<code>1 </code> - Only assigned fields are stored. Every assigned field outputs the following string <code>fieldindex</code> <var>vardel</var> <code>fieldvalue</code> <var>listdel</var>. E.g.: <code>c0=10.0 ; c1=10.1 ; c2= ; c3=10.3</code>
 
:<code>1 -</code> Only assigned fields are stored. Every assigned field outputs the following string <code>fieldindex</code> <var>vardel</var> <code>fieldvalue</code> <var>listdel</var>. E.g.: <code>c0=10.0 ; c1=10.1 ; c2= ; c3=10.3</code>


:Note: In order to load a table successfully, it must be loaded using the same format setting as was used to save it.
:Note: In order to load a table successfully, it must be loaded using the same format setting as was used to save it.


;<var>listdel</var>
;<var>listdel</var>
:delimiter string used to separate fields in the output line (for both formats). The special symbol '%t' can be used to specify the tab character. Consecutive white spaces (blanks and tabs) are interpreted as one delimiter. E.g. " 1 2 3" is interpreted as three fields, whereas ":1::2:3"
:delimiter string used to separate fields in the output line (for both formats). The special symbol '%t' can be used to specify the tab character. Consecutive white spaces (blanks and tabs) are interpreted as one delimiter. E.g. " 1 2 3" is interpreted as three fields, whereas ":1::2:3"


;<var>vardel</var>
;<var>vardel</var>
:delimiter string used to separate the <code>fieldindex</code> from the <code>fieldvalue</code> (for format <code>1</code> only)
:delimiter string used to separate the <code>fieldindex</code> from the <code>fieldvalue</code> (for format <code>1</code> only)


;<var>numfmt</var>
;<var>numfmt</var>
:Float format string used for all fields of type <code>NUMBER</code>. This can be any valid C string format specifier.
:Float format string used for all fields of type <code>NUMBER</code>. This can be any valid C string format specifier.


Line 497: Line 344:
:Integer (!) format string used for all fields of type <code>INTEGER</code>. This can be any valid C string format specifier.
:Integer (!) format string used for all fields of type <code>INTEGER</code>. This can be any valid C string format specifier.


You can set the decimal symbol using the <code>MODE</code> command.<pre>
You can set the decimal symbol using the [[#Setting_the_table_mode|<code>MODE</code>]] command.
<pre>
///////////////////////////////////////////////////////////////////////////////
///////////////////////////////////////////////////////////////////////////////
//
//
Line 552: Line 400:
== Locking / Unlocking the table ==
== Locking / Unlocking the table ==


Table items can be locked to prevent access by shells other than the locking shell.
The use of '''lock/unlock''' is only important, if a table item is (or may be) used by more than one thread. In {{STX}} shells, spu items and display item are running in their own thread.


See <code>lock_example.sts</code> in the script examples directory for an example.
SET <var>table</var> LOCK [/Save]
Lock the table item. The execution of the calling shell is stopped, until the item can be locked. If locked, only the shell which locked it has access to the item until it is explicitly unlocked with the command <code>UNLOCK</code>. Always beware of deadlocks.


=== LOCK ===
SET <var>table</var> LOCK <var>timeout</var> [Save]
Try to lock the table item, but wait only the specified time. This command returns '''0''' (success) if the lock request was successful within the timeout, and a non-zero error code if not. If the caller already ''holds'' the lock, the command will fail immediately. This makes sense because, since the caller is the owner, it cannot release it whilst its waiting. The argument <var>timeout</var> specifies the maximum lock-timeout in milliseconds and must be a number greater than zero.


<code>SET <var>table</var> LOCK [/Save]</code>
:* If the table is locked with the option '''/Save''', the tag state of each entry, the current order and the mode is saved on <code>lock</code> and restored with the <code>unlock</code> command. In this case in the critical section entries can only be modified, but not created or deleted.


Lock table access. If a table is locked, only the shell which locked it has access to its content. The table must be unlocked after finishing the 'critical' processing section.
SET <var>table</var> UNLOCK
Unlock the table item. '''Note''': It's very important that for each successful <code>LOCK</code>, an <code>UNLOCK</code> is called!


During the execution of most table commands, the table is automatically locked temporarily to the shell (by the table command). The table is also locked temporarily to a dialog during update processes. If the table is locked with the option /Save, the tag flags and the current order and mode is saved on lock and restored with the unlock command. In this case in the critical section entries can only be modified, but not created or deleted.
See <code>lock_example.sts</code> in the script examples directory for an example.
 
=== TRYLOCK ===
 
<code>SET <var>table</var> TRYLOCK [ <var>timeout</var> ] [ /S ]</code>
 
Try to lock the table item <var>table</var>. If no timeout is specified, <code>TRYLOCK</code> returns immediately. If the caller already *holds* the lock, <code>TRYLOCK</code> will fail immediately. This makes sense because, since the caller is the owner, it cannot release it whilst its waiting.
 
;<var>timeout</var>
 
:If specified, <code>TRYLOCK</code> will try to get a lock once per millisecond until it is either successful, or <var>timeout</var> milliseconds have elapsed.
 
;<var>/S</var>
 
:If specified, errors will generate warning messages rather than error messages. See The Silent Flag for details.
 
Return Codes:
 
<code>0</code> - an unlocked table has been successfully locked.
<code>381</code> - Error: if the table could not be locked due to it being locked by someone else.
<code>382</code> - Warning: identical to <code>381</code>, except that this returned when the /S flag is specified.
<code>383</code> - Error: if the table could not be locked due to it being locked by the caller.
<code>384</code> - Warning: identical to <code>383</code>, except that this returned when the /S flag is specified.
 
Example:
 
"<code>SET $#table TRYLOCK 5000</code>" will try hard to lock the table. If it does not succeed within 5000ms (i.e., five seconds), it will fail - but it will not fail earlier.
 
The <code>TRYLOCK</code> command is intended for safe multithreading without race conditions occurring
 
=== UNLOCK ===
 
<code>SET <var>table</var> UNLOCK</code>
 
Unlock table access.


== Setting the table mode ==
== Setting the table mode ==


This command is only applicable to extended tables
This command is only applicable for [[Programmer_Guide/Concepts/Extended_table|extended tables]].
 
=== MODE ===


<code>SET <var>table</var> MODE <var>mode</var> [<var>access format decimal</var>]</code>
SET <var>table</var> MODE <var>mode</var> [<var>access format decimal</var>]


Set table mode (configuration / data) and general attributes.
Set table mode (configuration / data) and general attributes.
Line 618: Line 433:
;<var>format</var>
;<var>format</var>


:Selects the format to be used for file I/O: <code>0</code>=show format, <code>1</code>=write (default) format.
:Selects the format to be used for file I/O: <code>0</code>&hellip;[[Programmer_Guide/Shell_Items/Table/Introducing_Table_Items#The_Show_Format|show format]], <code>1</code>&hellip;[[Programmer_Guide/Shell_Items/Table/Introducing_Table_Items#The_Write_Format|write (default) format]].


;<var>decimal</var>
;<var>decimal</var>
Line 628: Line 443:
== Showing and hiding table entries ==
== Showing and hiding table entries ==


<code>SET <var>table</var> /All|Tagged</code>
SET <var>table</var> /All|Tagged


Make all table entries visible (/A) or only tagged entries visible (/T).
Make either all table entries visible (<code>/All</code>) or only tagged entries (<code>/Tagged</code>).


Only visible entries can be accessed, deleted or displayed (e.g. in a list box).
Only visible entries can be accessed, deleted or displayed (e.g. in a list box).
Line 636: Line 451:
== Sorting table entries ==
== Sorting table entries ==


=== SORT ===
SET <var>table</var> SORT [/Respect]


<code>SET <var>table</var> SORT [/Respect]</code>
Invert entry order (all tables) <!-- wie bitte!? -->


Invert entry order (all tables)
For simple tables:


for simple tables
SET <var>table</var> SORT <var>dir</var> [/Respect]


<code>SET <var>table</var> SORT <var>dir</var> [/Respect]</code>
For extended tables:


for extended tables
SET <var>table</var> SORT <var>fieldid dir</var> [&hellip;] [/Respect]


<code>SET <var>table</var> SORT <var>fieldid dir</var> [...] [/Respect]</code>
Sort table entries. For simple tables only the sort direction (<var>dir</var>: Ascending (0), Descending (1)) can be selected.


Sort table entries. For simple tables only the sort direction (<var>dir</var>: Ascending (0), Descending (1)) can be selected. For extended tables one or more fields and the sort direction can be specified. The sort function ignores the visibility setting and sorts all table entries! If the option /Respect is used, strings are sorted respecting their case, otherwise the sort is case-insensitive.
For extended tables, one or more fields and the sort direction can be specified. The sort function ignores the visibility setting and sorts all table entries. If the option <code>/Respect</code> is used, strings are sorted respecting their case, otherwise the sort is case-insensitive.


== Tagging table entries ==
== Tagging table entries ==


<code>SET <var>table</var> /Reset|Invert</code>
SET <var>table</var> /Reset|Invert


Reset (/Reset) or invert (/Invert) tag flags of all entries and set visibility to ALL.
Reset (/Reset) or invert (/Invert) tag flags of all entries and set visibility to ALL.


<code>SET <var>table index</var> /Tag|Untag|Invert</code>
SET <var>table index</var> /Tag|Untag|Invert


Set, clear or invert tag flag of an entry. These options can also be used in all table commands assigning a value.
Set, clear or invert tag flag of an entry. These options can also be used in all table commands assigning a value.


The command <code>TAGS</code> can be used to save and restore a table's tagged entries.
The command <code>TAGS</code> can be used to save and restore a table's tagged entries.

Latest revision as of 10:30, 30 January 2019

Table Item
INTRODUCTION NEW SET ATTRIBUTES

The SET table command is used to modify a table item. The sub-commands documented here are valid for all table types, unless otherwise specified.

Setting or Adding table entries

SET table index|* … [ /Tag | /Untag ]

When using the index of an existing entry for index, the command will modify the respective entry. When supplying the asterisk, "*", for index, a new entry will be appended to the end of the table. Finally, when supplying a value for index that is greater than the number of entries (table[]), the table will be padded with an appropriate number of empty entries in order to allow the entry index to be set.

The options /Tag and /Untag may be used for setting or clearing the tag flag.

Remember that with STx table indexes are always zero-based.

Unstructured adding

SET table index|* entryValue [ /Tag|Untag ]

This statement is the sole way of adding entries to a simple table. The statement is applicable to extended tables, too. With extended tables, the field separator character may be used to separate fields in the string entryValue, meaning that entryValue will be parsed in the same way as entries are loaded from files.

index The zero-based index of an existing entry to modify the entry's data or a zero-based index greater than the number of existing entries, to add a new entry. If the index is greater than the total number of entries, then all missing entries are created and initialized with default values. An asterisk may be used to append the table with a new entry at the next free index.
entryValue The value to assign to the entry.
/Tag or /Untag tag, or untag, the respective entry

Adding structured data to extended tables

SET table index|* fieldId1 fieldValue1 [ … fieldIdn fieldValuen ] [ /Tag|Untag ] [ /N=n|all|tagged ]

The structured variant of setting entries allows to address the fields of an entry. It is thus applicable to extended tables only. Using the option /N, you may even set multiple entries at the same time.

index The zero-based index of an existing entry to modify the entry's data or a zero-based index greater than the number of existing entries, to add a new entry. If the index is greater than the total number of entries, then all missing entries are created and initialized with default values. An asterisk may be used to append the table with a new entry at the next free index.
fieldId1 A valid field id (as defined in the NEW TABLE command) or a field index.
fieldValue1 The value to assign to the respective field.
/Tag or /Untag tag, or untag, the respective entry
/N=n Repeat this assignment for the next n entries (with /N=n and n being an integer higher than, or equal to, 1), or for all entries from the current one to the last one (with /N=all), or for all tagged entries from the current one to the last one (/N=tagged). Note that the all and tagged variants cannot append new entries to the table. Note also that you cannot set 'all' entries, if only tagged entries are currently visible.
// initialize the first field of the first 10 entries with the value 0.
$#extTable 0 0 0 /N=10

Retrieving a table entry

You can retrieve a table entry using the following syntax: $#table[$#index]. If the table has columns defined, you can use the syntax $#table[$#index,$#columnid].

Configuring a table field

The SET table CONFIG command is only applicable to extended tables (after all, simple tables do not have fields).

SET table CONFIG fieldid [ show name scale format mmode mval msym header width align sort editable
                         [ listtable listfield listonly setdefault setuserdefault multirow ] ]

Configure a table field. Define the display format (list box and list view) and field properties. The field must have been specified in the NEW TABLE command. The table must be in configuration mode (see MODE).

fieldid The name or index of the field to be configured / updated.
show Show (1 or ON) or hide (0 or OFF) the field in listbox and list view controls
name Show both name and value (1 or ON) or value only (0 or OFF) in list box controls. This is only effective if show is ON.
scale The scaling factor for numeric fields; if a numeric field is accessed in the show format, its value is multiplied with scale (used by both listboxes and listviews).
format The show format format string.

For fields of type NAME or STRING, the format must contain a string tag (e.g.: %s, %10.10s) For both numeric field types (INTEGER and NUMBER), the format must contain a float tag (%f, %g). The float tag is necessary for integer values because the scaling factor (scale) is a floating number.

Note that to display an integer (without decimals) you can use the format tag %5.0f. This parameter controls the format for listboxes and listviews dialog controls.

mmode ON) or disable (0|OFF) missing value replacement. Missing value replacement is disabled by default. If enabled, missing values are replaced by msym.
mval The numeric id value of a 'missing value' (e.g. 0 for f0 data). The default is 0. Missing value replacement only works for numerical fields (NUMBER or INTEGER).
msym The replacement symbol (string) for missing values (e.g. UNVOICED for f0 data). The strings <empty> and <blank> can be used to replace a missing value with an empty string or a blank character. The default string is the empty string.
header The text to be displayed in the field's column header of a listview control.
width The width (in characters) of the column of a listview control.
align Align field left (0) or right (1) in the column of a listview control; The first column of a listview is always. left-aligned (align is ignored)
sort Enable (1) or disable (0) the sort function of the column header of a listview control.
editable If editable is set to 0, the respective field (column) of the table is NOT editable when the table is connected to a ListView item. If editable is set to a number different from 0, the respective field (column) of the table IS editable when the table is connected to a ListView item. See the example script editabletable.sts for a complete example.
listtable The name of a table containing all permissible values for this field. If this table (table) is connected to a listview item, and the listtable parameter is specified, the listview displays a combobox in the associated column, and fills the combobox with listtable's values.
listfield The field id specifying the field in listtable where the values are stored. If listtable is a simple table, listfield must be 0.
listonly The listonly parameter specifies whether this table's field may only use values in the list table (1), or whether any values may be entered (0). If 0, then the combobox is editable.
setdefault The setdefault parameter specifies whether invalid or empty data entered whilst editing should be replaced by the default value (1=yes, 0=no). The first value in the list table is the default value.
setuserdefault If set to ON or 1, the last user-input for this field will be used as the respective default value.
multirow If set to 1 or ON, the field can display text in multiple rows. If set to 0 or OFF, text will be displayed in one row. The default is OFF.

A field is defined once, but can be configured as often as needed. If an argument is not supplied or set to '*', the configuration for that parameter is not changed.See the example script editabletable.sts for a detailed example.

Table-to-table Copy

SET table COPY srctable [fieldid … ] [ /Rows /Columns ]

Copy data from the source table srcTable (a parameter table or an extended table) to the target table table (a table of the same kind). If fields (fieldids) are specified, then only these fields are copied. Otherwise all fields of the source table are copied.

If the command is called without supplying options /Rows or /Columns), then

  1. the source table must have the same format, i.e. the same fields, as the target table; and
  2. the source entries will overwrite the target entries (appending entries if necessary).

If the command is called with either option /Rows or /Columns, the command will not overwrite existing entries and fields in the target table. Rather than that, the command will modify the target table, appending source fields (which do not exist in the target table) and entries to the target table. Note that the target table must have enough undefined fields to accommodate the appended fields (i.e. fields created by NEW TABLE, but yet undefined).

Note that the COPY command works only with extended and with parameter tables.

srctable
The table to copy from. This must be an extended or parameter table.
fieldid
An optional list of field IDs, separated by blank. If specified, only these fields are copied. If omitted, all fields are copied.
/Rows
If specified, fields from srctable are appended to table. The fields being copied must already be defined in table. Note that the field data type is not checked (i.e. number fields can be copied to string fields of the same name).
/Columns
If specified, entries from srctable are copied to the same entries in table, overwriting their old value. Fields not defined in table are automatically defined and configured. For this reason there must be enough undefined fields in table.

Copying between a Table and a Value Item

SET table COPY outputName i j [ /Row|Col ] [ /Write ]

Copy data between a table and a value object. If the option /Write is used, the table data is copied to the value item, otherwise (default) the value item data is copied to the table.

outputName
The name of a value item to copy to or from.
i
The entry index.
j
The field index.
/Row
Copy table fields starting at row i field j. The number of fields copied is determined by the size of the vector. The number of rows copied is determined by the number of vectors (only for array value items). This option is only for array and vector value items.
/Col
Copy table entries starting at row i, field j. The number of rows copied is determined by the size of the vector. The number of fields copied is determined by the number of vectors (array value items). This option is only for array and vector value items.
/Write
If the option /Write is specified, the table data is copied to the value item. If omitted, the value item data is copied to the table.

Copying to and from the clipboard

SET table CLIPBOARD [ /Show|Write ]

Copy the visible entries of a table to the clipboard. The entries can be copied either in:

  1. show-format, i.e. using listbox display format, when supplying the /Show option (or no option at all, since this is the default); or in
  2. write-format, i.e. the format normally used when writing to a file. This is done with the /Write option.
/Show
Use the show format to format each entry string. This is the default.
/Write
Use the write format to format each entry string.
SET table CLIPBOARD /Args arg1 arg2 ... [ /Show|Write ]

Copy the content of the arguments to the clipboard. Each argument argI can be a string (string is copied) or a table item (content of table is copied). The option /Show|Write specifies the output format used for the table items (as described above). The content of the table item table is only copied, if it is specified as argument.

SET table CLIPBOARD /Read [ /Delete ] [ /Empty ]

Read the last entry from the clipboard. This will work only if the format of the respective clipboard entry is either Unicode (CF_UNICODETEXT) or text (CF_TEXT).

/Read
Mandatory option.
/Delete
Delete the table entries before reading from the clipboard.
/Empty
Empty the clipboard after a successful read.

Defining a table field

SET table DEFINE index|* type name [count offset] [/Auto] [/Undefine]

Note that the table must be in configuration mode (see MODE). Define the data type and name of field index (0 .. number of fields - 1). If an asterisk '*' is given instead of index, the first free (undefined) index is used. The argument type is the id of the data type of the field. The argument name is the name to be assigned to the field and must be a valid name string. The parameters count and offset can be used to define multiple fields with one command (count = number of fields, offset = base index). The option /Auto ensures the name is unique by concatenating the string name with an index (first value: 1). Note that once you have configured the table, you need to switch to DATA mode (see MODE below).

The SET table DEFINE command is only applicable to extended tables, since only they support different types of fields.

index
The index of the field to be defined or '*' for the next free index.
type
The type of data to be stored. The following values are supported:
NAME - Strings which are valid names.
STRING - Free text.
INTEGER - Integer numbers.
NUMBER - Floating point numbers.
name
The name to assign to the field. Note that this must also be a valid name.
count
The number of fields to define. Used in conjunction with offset for multiple definitions. Must be >= 1.
offset
The index to start multiple definitions with. Must be >= 0.

Undefining a table field

SET table DEFINE index|name [… /Undefine]

Undefine an existing field and delete contents of all field entries. Multiple undefines are possible by using the option /Undefine in conjunction with multiple parameters.

index|name
The index or name of the field(s) to undefine.

Renaming a table field

SET table DEFINE fieldName newName /Rename

Rename an existing field.

fieldName
The existing field name.
newName
The new field name
/R
The mandatory option /Rename, specifying that this DEFINE command should rename the field.

An example can be found in the macro file table_redefine.sts.

Deleting table entries

SET table [index] /Delete

Delete all visible entries or the specified entry index.

Finding table entries

The FIND function implements a simple 'database query' interface for tables. To create complex queries, it may be necessary to apply a set of FINDs and possibly combine them with the FIND command. The FIND function only searches tagged entries. Therefore, if you want to search the whole table, you must tag all the entries first. At the end of a query (any number of FIND function calls), the tagged entries are those matching the search criteria.

SET table FIND

Initialize a new find cycle. The tag flag of all entries are set and visibility is set to ALL. This command should be issued before a new query consisting of multiple commands is started. Instead of this command the option /Start can be used with the (first) FIND.

SET table FIND cexpr [loper cexpr ...] [/Start /Invert /Tagged]

Search for all tagged entries matching the criteria defined by the cexpr and loper arguments. The tag flags of all not matching entries are cleared. The logical operators are evaluated strictly from left to right. This means the result of all expressions of the left side of an operator is combined with the result of the expression on the right side. The logical operators AND (=&&), OR (=||) and XOR (=^^) are defined. Note that the field value for simple tables is 0.

cexpr
The expression defining one search criterion (see Find expressions for details).
loper
The logical operator combining two search criteria; logical operators are applied from left to right, bracketing is not possible. The following operators are supported:
conjunction: AND or &&
disjunction: OR or ||
exclusive disjunction: XOR or ^^
/Start
Initialize a new find cycle (this is like a call to FIND without arguments and is applied before query).
/Invert
Invert all tag flags (applied after query).
/Tagged
Switch to visibility "tagged" (applied after query).
// search for entries where key field ends with 'ing'
// and show only tagged entries
$#t find 'key:=I:*ing' /Tagged

Find expressions

cexpr Description
fieldid:cond
fieldid name or index of a defined field
cond = (is assigned), ! (is not assigned)


fieldid:cond:value
fieldid name or index of a numerical field (0 for simple tables)
cond <, <=, ==, !=, >= or >
value a number or numerical expression, or a string.


fieldid:cond:mask
fieldid name or index of a string field (0 for simple tables)
cond =I match, ignoring case
!I do not match, ignoring case
=R match, respecting case
!R do not match, respecting case
mask match string, may contain wildcard characters. if field is of type name, mask must be a valid name

Regular expressions

S_TOOLS-STx supports searches using POSIX regular expression. When using regular expressions, characters which have a special meaning in STx will need to be escaped using the STx escape character "`".

fieldid:cond:regex
fieldid name or index of a string field (0 for simple tables)
cond =RI matching regular expression ignoring case
=RR matching regular expression respecting case
!RI not matching regular expression even if ignoring case
!RR not matching regular expression if respecting case.
regex a POSIX regular expression.

The script regular_expressions.sts provides examples of usage.

Formatting table fields

Formatting is only applicable to extended tables.

SET table FORMAT format [listdel vardel numfmt  intfmt]

Configuration of the write format used to save and load tables from files (see SET file LOAD and SET file SAVE). You can configure the show format (used to display tables in the GUI) using the CONFIG command.

format
0 - Store all fields even if they are empty. Assigned fields have the format fieldvalue listdel and empty fields have just the listdel. E.g.: 10.0 ; 10.1 ; ; 10.3
1 - Only assigned fields are stored. Every assigned field outputs the following string fieldindex vardel fieldvalue listdel. E.g.: c0=10.0 ; c1=10.1 ; c2= ; c3=10.3
Note: In order to load a table successfully, it must be loaded using the same format setting as was used to save it.
listdel
delimiter string used to separate fields in the output line (for both formats). The special symbol '%t' can be used to specify the tab character. Consecutive white spaces (blanks and tabs) are interpreted as one delimiter. E.g. " 1 2 3" is interpreted as three fields, whereas ":1::2:3"
vardel
delimiter string used to separate the fieldindex from the fieldvalue (for format 1 only)
numfmt
Float format string used for all fields of type NUMBER. This can be any valid C string format specifier.
intfmt
Integer (!) format string used for all fields of type INTEGER. This can be any valid C string format specifier.

You can set the decimal symbol using the MODE command.

///////////////////////////////////////////////////////////////////////////////
//
//    Macro:          load_a_file_into_a_table.sts
//    Description:    load the contents of a numeric text file into a parameter
//                    table and displays the table if desired
//    Parameters:     #fileName    the file to load
//                    #mode        0    silent
//                                 1    show table
//                                 2    return table
//    Return:         0 on success, non-zero on failure
//    Usage:          load_a_file_into_a_table [file] ; [show]
//    Author:         Jonnie White
//    History:        2005-03-31    jw    created
//                    2005-04-27    jw    added new mode (return table) and file 
//                                        parameter
//
///////////////////////////////////////////////////////////////////////////////
[macro load_a_file_into_a_table]
    #fileName := set '$scriptDirectory\input_matrix_small.txt'
    #mode := 1
    readvar #argv #fileName';'#mode

    // create a parameter table with 4 fields
    #tableItem := new table * 4 /Parameter number:f:4
    if '$#tableItem' == * em -1 ; failed to create a table
    
    // set the write format to blank separated
    $#tableItem format 0 ' '
    
    // create the read-only file object associated with fileName
    #fileItem := new file * '$#fileName' /Text /Read
    if '$#fileItem' == * em -1 ; failed to open the file $#fileName
    
    // load the file into the table
    $#fileItem load $#tableItem
    if '$rc' > 0 em -1 ; failed to load file $#fileName into table $#tableItem
    
    // show the table
    if '$#mode' == 1 showitem $#tableItem
    
    // return table
    if '$#mode' == 2 then
        delete $#fileItem
        exit 1 set '$#tableItem'
    else
        // clean up
        delete $#fileItem $#tableItem
    end
exit 1 int 0

Note that if you need to save a table containing empty fields, you should *not* use a blank or a tab character as the delimiter. If you do, the empty fields will be omitted on loading the table.

Locking / Unlocking the table

The use of lock/unlock is only important, if a table item is (or may be) used by more than one thread. In STx shells, spu items and display item are running in their own thread.

SET table LOCK [/Save]

Lock the table item. The execution of the calling shell is stopped, until the item can be locked. If locked, only the shell which locked it has access to the item until it is explicitly unlocked with the command UNLOCK. Always beware of deadlocks.

SET table LOCK timeout [Save]

Try to lock the table item, but wait only the specified time. This command returns 0 (success) if the lock request was successful within the timeout, and a non-zero error code if not. If the caller already holds the lock, the command will fail immediately. This makes sense because, since the caller is the owner, it cannot release it whilst its waiting. The argument timeout specifies the maximum lock-timeout in milliseconds and must be a number greater than zero.

  • If the table is locked with the option /Save, the tag state of each entry, the current order and the mode is saved on lock and restored with the unlock command. In this case in the critical section entries can only be modified, but not created or deleted.
SET table UNLOCK

Unlock the table item. Note: It's very important that for each successful LOCK, an UNLOCK is called!

See lock_example.sts in the script examples directory for an example.

Setting the table mode

This command is only applicable for extended tables.

SET table MODE mode [access format decimal]

Set table mode (configuration / data) and general attributes.

mode
A flag to switch the table mode to configuration mode (0) or data mode (1); After creating an extended table the table may be in configuration or data mode, depending on the NEW command. See NEW table for details.
access
This argument is currently meaningless. It is reserved for future database functions and should be set to '0' or '*'.
format
Selects the format to be used for file I/O: 0show format, 1write (default) format.
decimal
Sets the character to be used as the decimal symbol. By default, the period '.' is used.

Since STx 3.7.0, the NEW TABLE syntax has been modified to include the field definitions. The table mode is then automatically set to data, and hence this command may in future be pretty much obsolete, except for setting the decimal symbol.

Showing and hiding table entries

SET table /All|Tagged

Make either all table entries visible (/All) or only tagged entries (/Tagged).

Only visible entries can be accessed, deleted or displayed (e.g. in a list box).

Sorting table entries

SET table SORT [/Respect]

Invert entry order (all tables)

For simple tables:

SET table SORT dir [/Respect]

For extended tables:

SET table SORT fieldid dir […] [/Respect]

Sort table entries. For simple tables only the sort direction (dir: Ascending (0), Descending (1)) can be selected.

For extended tables, one or more fields and the sort direction can be specified. The sort function ignores the visibility setting and sorts all table entries. If the option /Respect is used, strings are sorted respecting their case, otherwise the sort is case-insensitive.

Tagging table entries

SET table /Reset|Invert

Reset (/Reset) or invert (/Invert) tag flags of all entries and set visibility to ALL.

SET table index /Tag|Untag|Invert

Set, clear or invert tag flag of an entry. These options can also be used in all table commands assigning a value.

The command TAGS can be used to save and restore a table's tagged entries.

Navigation menu

Personal tools