Programmer Guide/Macro Library/BSTXIni: Difference between revisions
No edit summary |
|||
Line 1: | Line 1: | ||
{{DISPLAYTITLE:{{SUBPAGENAME}}}} | {{DISPLAYTITLE:{{SUBPAGENAME}} - Workspace Document}} | ||
:'''File''': BSTXIni.STX, linked to library STX.LIB | |||
:'''Parent class''': [[Programmer Guide/Macro Library/BXMLDoc|BXMLDoc]] | |||
This class implements the | :'''See also''': [[Programmer_Guide/Macro_Library/BDataSet|BDataSet]] | ||
This class implements the '''workspace document'''. The workspace document contains the {{STX}} configuration and the settings and is implemented as a global object which can be accessed from all {{STX}} applications and scripts. The user must not create or destroy the workspace object because these functions are performed by the application startup and cleanup macros. At application startup, a <code>BSTXINI</code> instance is created and linked to the global workspace document. The name of is instance is stored in the shell variable '''BSTXINI'''. This instance must (!) be used to access the workspace document. | |||
This class also implements a set of static functions which are used by the master application and the application DataSet to manage to file STX.INI which contains the name of the last used workspace file (for program startup) and the project file history. The automatic workspace version update and some installation and licence checks are also implemented by this class, but not described in this documentation. | |||
::'''Important note''': A shell or a script should only access or change the content of the workspace document, while it is attached (locked). This is very important, because this document can be (and is often) accessed by all running shells (e.g. {{STx}} applications or scripts). A code section accessing the workspace content should start with <code>$bstxini attach</code> and end with <code>$bstxini detach</code>. See [[Programmer_Guide/Macro_Library/BXMLDoc|#Access_control]] for details. | |||
Please use the ATTACH and DETACH functions from the base class [[Programmer Guide/Class Library/BXMLDoc : CObj|BXMLDOC]] before carrying out any actions on shared documents. | Please use the ATTACH and DETACH functions from the base class [[Programmer Guide/Class Library/BXMLDoc : CObj|BXMLDOC]] before carrying out any actions on shared documents. |
Revision as of 14:32, 2 March 2018
This class implements the workspace document. The workspace document contains the STx configuration and the settings and is implemented as a global object which can be accessed from all STx applications and scripts. The user must not create or destroy the workspace object because these functions are performed by the application startup and cleanup macros. At application startup, a BSTXINI
instance is created and linked to the global workspace document. The name of is instance is stored in the shell variable BSTXINI. This instance must (!) be used to access the workspace document.
This class also implements a set of static functions which are used by the master application and the application DataSet to manage to file STX.INI which contains the name of the last used workspace file (for program startup) and the project file history. The automatic workspace version update and some installation and licence checks are also implemented by this class, but not described in this documentation.
- Important note: A shell or a script should only access or change the content of the workspace document, while it is attached (locked). This is very important, because this document can be (and is often) accessed by all running shells (e.g. STx applications or scripts). A code section accessing the workspace content should start with
$bstxini attach
and end with$bstxini detach
. See #Access_control for details.
- Important note: A shell or a script should only access or change the content of the workspace document, while it is attached (locked). This is very important, because this document can be (and is often) accessed by all running shells (e.g. STx applications or scripts). A code section accessing the workspace content should start with
Please use the ATTACH and DETACH functions from the base class BXMLDOC before carrying out any actions on shared documents.
!! Never call the member functions CONSTRUCT, DESTRUCT, CLOSE or LOAD !!
Contents
- 1 BSTxIni Static Functions
- 2 BSTXIni Member Functions
- 2.1 DELETESETUPELEMENT tag ; id ; templateid ; ref
- 2.2 DIALOGNEWSETUPELEMENT title ; tag ; ref
- 2.3 GetApp
- 2.4 GetVersion
- 2.5 LISTPROFILES table ; tag ; id ; ref
- 2.6 LOADAPPSETUP app ; subapp ; profile
- 2.7 LoadColorSetup
- 2.8 LoadSetupElement
- 2.9 SAVEAPPSETUP app ; subapp ; profile
- 2.10 SaveColorSetup
- 2.11 SaveSetupElement
BSTxIni Static Functions
The following functions can be called without a BSTXINI instance.
BSTXINI ?
Get last workspace.
BSTXINI ? file
Set the last workspace.
BSTXINI *
Get the project history list.
BSTXINI + file
Add the project file to the history list.
BSTXINI - file
Remove the project file file from history list.
BSTXINI SelectDataset
Display a dialog asking the user to choose the a project file to load from the list of previous projects. If the user cancels, the last used project is returned, otherwise the user's choice is returned (file path).
BSTXINI Scripts [add file]
Return a list of recently used scripts. If the command add
and a file parameter are specified, then the script file is added to the list of recently used scripts.
BSTXIni Member Functions
The BSTXIni
class has the following member functions. See BXMLDoc Member Functions for a list of functions implemented in the parent class.
DELETESETUPELEMENT tag ; id ; templateid ; ref
Deletes the specified profile element.
usage:
tag | profile element tag |
id | profile element id |
ref | relative profile set reference |
result:
none
DIALOGNEWSETUPELEMENT title ; tag ; ref
usage:
title | dialog window caption |
tag | profile element tag |
ref | relative profile set reference |
result:
name of created profile or empty string for error/cancel
description:
Opens a dialog to enter a profile name and creates an empty profile element.
GetApp
Get an applications shell by name.
Usage:
inst GetApp [ appName ]
Parameters:
- appName
- The name of an installed application.
Result:
The shell id of the running application.
GetVersion
Retrieve program version information. The build type is either Unicode or ASCII.
Result:
'version-number ; build-type ; release-date ; revision'
Examples:
3.7.6 ; Unicode ; 25 September 2005 ; 2887
LISTPROFILES table ; tag ; id ; ref
usage:
table | name of target table or * to create a new table |
tag | profile element tag |
id | id of default/selected profile |
ref | relative reference of element containing profiles |
result:
table containing list of profile id's and the index of the default/selected profile ('table index')
description:
Creates a sorted list of the id's of all child elements of the specified profile set with the specified tag.
LOADAPPSETUP app ; subapp ; profile
usage:
app | name of application |
subapp | name of sub-application or function |
profile | name of application profile |
result:
none
description:
Load all application settings for the specified application and convert loaded settings to shell or global variables.
LoadColorSetup
Load graphics settings, colors and palettes from a color-scheme profile.
Usage:
inst LoadColorSetup [ profile ]
Parameters:
- profile
- The color scheme profile to load. If this is not specified, the color scheme 'default' is used.
Result:
The id's of four tables.
screenColors printColors screenPalette printPalette
LoadSetupElement
Load the specified profile element data and return the loaded data. If the profile do not exist, the specified profile template element is used to create it.
Usage:
inst LoadSetupElement tag ; id ; templateid ; ref
Parameters:
- tag
- The profile element tag.
- id
- The profile element id.
- templateid
- The profile element id or * to use the value of id.
- ref
- The relative profile set reference.
Result:
The name of table containing loaded data or empty string if load fails
SAVEAPPSETUP app ; subapp ; profile
usage:
app | name of application |
subapp | name of sub-application or function |
profile | name of application profile |
result:
none
description:
Store all application setup variables into a table and save the table into the setup elements specified by the arguments.
SaveColorSetup
Save graphics settings, colors and palettes in a color-scheme profile.
Usage:
inst SaveColorSetup [ profile ] ; delete ; screenColors ; printColors ; screenPalette ; printPalette
Parameters:
- profile
- The color scheme profile to load. If this is not specified, the color scheme 'default' is used.
- delete
- Set to 1 if the tables arguments should be deleted before returning.
- screenColors, printColors, screenPalette, printPalette
- The id's of tables containing the settings.
Result:
None.
SaveSetupElement
Save the table in the specified profile element. If the profile does not exist it is created.
Usage:
inst SaveSetupElement table ; del ; tag ; id ; ref
Parameters:
- table
- The table containing the profile data.
- del
- If 1, the table is deleted after saving. If 0, the table is not deleted.
- tag
- The XML element tag to save to. One of the following values:
- Table - if table is a simple table
- XTable - If you table is an extended table
- id
- The value to set the XML attribute 'ID' to.
- ref
- The relative profile set reference .
Result:
0 for success or non-zero error code