The Registry Service Class
The service class
Registry maintains a directory which stores named settings and options for a running application. It contains a simple hierarchical set of name-value pairs stored under the root symbol
IMSLIB.Registry. The use and content of these name-value pairs is entirely up to the applications. The
Registry class is introduced to tidy up the profusion of application specific startup-files and own-coded runtime options that tend to propagate in language processing applications.
Though the design of the registry is based on the "Windows registry" its content consists simply of string and text stream types. It has no internal value types and has no system defined content beyond the value of its root symbol which is defined privately within the class implementation. Any storage area may contain registry information. Its intent is to simplify the design of complex applications without itself introducing new complexity or extensive machinery.
A "location" in the registry is a nonterminal-node in the storage area of that contains a list of unique names each of which is assigned a non-empty string or text stream value. Note that at given level in the tree, a location may well have a value associated with it thus, being both a pair and the parent of a list of pairs.
The method Registry_Declare
Prototype Code Block |
---|
language | cpp |
---|
theme | Eclipse |
---|
linenumbers | true |
---|
|
int Registry_Declare(CONST char* location,char* name,char* value);
|
The
Registry_Declare method declares a new name-value pair in the registry. Its parameters are as follows:
Parameter | Description |
ocation | Contains the full identifier of the location of the name-value pair. This identifier consists of the names of nonterminal nodes above the pair, separated by periods. The node identifiers themselves should be simple identifiers beginning with a letter and containing only letters and numbers. |
name | Contains the name of the pair to be posted to the terminal location node. It may have any content. If a given pair is intended to be unique within a given location, then its name must be unique within that location only. If the registry, or the location, or the name do not yet exist, in the storage area then they are created. If they do all exist, then the previous value associated with the name is lost. |
value | Contains the value string to be associated with the name. It may be NULL which indicates that this name is to have a text stream as its associated value. |
If all goes well, the method returns root offset in storage of the name-value pair; else it returns zero.
The method Registry_GetLocation
Prototype Code Block |
---|
language | cpp |
---|
theme | Eclipse |
---|
linenumbers | true |
---|
|
int Registry_GetLocation(CONST char* identifier);
|
The
Registry_GetLocation method gets the location of pairs in the registry. Its parameter is:
Parameter | Description |
identifier | Contains the full identifier of the location of a name-value pair. This identifier consists of the names of nonterminal nodes above the pair, separated by periods. The node identifiers themselves should be simple identifiers beginning with a letter and containing only letters and numbers. |
If the specified location does not exist, then a zero is returned; else the root offset of the location is returned. Note that the pairs are then simply the children of this location.
The method Registry_GetNameRoot
Prototype Code Block |
---|
language | cpp |
---|
theme | Eclipse |
---|
linenumbers | true |
---|
|
int Registry_GetNameRoot(CONST char* location,char* name);
|
The
Registry_GetNameRoot method gets the root offset of a name in the registry. Its parameters are:
Parameter | Description |
location | Contains the full identifier of the location of the name pair. This identifier consists of the names of nonterminal nodes above the pair, separated by periods. The node identifiers themselves should be simple identifiers beginning with a letter and containing only letters and numbers. |
name | Contains the name to be found. |
If the name is not defined at the specified location a zero is returned; else its root offset is returned. Note that this is the same value as returned by
Registry_Declare() when the name was first declared.
The method Registry_GetNameValue
Prototype Code Block |
---|
language | cpp |
---|
theme | Eclipse |
---|
linenumbers | true |
---|
|
int Registry_GetNameValue(CONST char* location,char* name,char* value);
|
The
Registry_GetNameValue method gets the value of a name-value pair in the registry. Its parameters are as follows:
Parameter | Description |
location | Contains the full identifier of the location of the name value pair. This identifier consists of the names of nonterminal nodes above the pair, separated by periods. The node identifiers themselves should be simple identifiers beginning with a letter and containing only letters and numbers. |
name | Contains the name of the pair. It may have any content. |
value | Receives the value of the pair in null-terminated form. If the specified pair was not found or if that pair has no value associated with it, then the entry content of this parameter is not changed. |
If there is no value associated with the pair either because the pair does not exist or because it has no value, then a zero is returned. If there is a string value associated with the pair, then its content is stored in the
value property and its length is the return value. If there is a text stream associated with the name, then the negative of its root offset is returned.
The method Registry_GetTextValue
Prototype Code Block |
---|
language | cpp |
---|
theme | Eclipse |
---|
linenumbers | true |
---|
|
int Registry_GetTextValue(int pairRoot);
|
The
Registry_GetTextValue method gets the value of a registered name-value pair equal to reference a text stream as opposed to a simple string value. Its parameter is:
Parameter | Description |
pairRoot | Specifies the root offset of the pair as returned by the method Registry_Declare. |
The method returns the root offset of the text stream associated with the pair.
The method Registry_RuntimeGuid
Prototype Code Block |
---|
language | cpp |
---|
theme | Eclipse |
---|
linenumbers | true |
---|
|
int Registry_RuntimeGuid(char* guidName,char* buffer);
|
The
Registry_RuntimeGuid method checks the runtime registries for a
Guid terminal registry type. The user storage area is checked first, then the language area. Its parameters are:
Parameter | Description |
guidName | Contains the source name for the guid. It may be NULL. |
buffer | Receives the guid associated with the specified source name. |
This method attempts to find a
Guid type entry whose source matches
guidName. If found, the target value is the guid to be used. If not found a new guid is generated via the operating system and returned.
The method Registry_SetTextValue
Prototype Code Block |
---|
language | cpp |
---|
theme | Eclipse |
---|
linenumbers | true |
---|
|
void Registry_SetTextValue(int pairRoot,int textRoot);
|
The
Registry_SetTextValue method sets the value of a registered name-value pair equal to reference a text stream as opposed to a simple string value. Its parameters are:
Parameter | Description |
pairRoot | Specifies the root offset of the pair as returned by the method Registry_Declare. |
textRoot | Specifies the root offset of the text stream to be associated with the pair. |