Each IDLTask is defined by a set of parameters. Each has constraints on data type, values, etc. The IDLParameterDictionary is used when an IDLTask has a parameter defined as type of DICTIONARY.
Syntax
Result = IDLParameterDictionary( [, Properties=value])
Properties
Properties can be set as keywords to the function during creation, or retrieved using the "." notation after creation. The NAME property is required on initialization. The VALUE property is the only property that can be updated after creation.
ALLOW_NULL, DEFAULT, DESCRIPTION, DIRECTION, DISPLAY_NAME, NAME, REQUIRED, TYPE, VALUE
Methods
Dehydrate
Hydrate
Validate
Return Value
Returns a reference to a newly-created object.
Properties
ALLOW_NULL
A Boolean value that indicates whether NullObject values are allowed or not. The default is 0, which causes NullObject values to fail validation. In the task template, this is defined with the allow_null key.
DEFAULT
The default value of the parameter. The default is !NULL. The values of this property must adhere to the TYPE property. In the task template this is defined with the "default" key.
DESCRIPTION
A string describing the purpose of the parameter with respect to the task. In the task template this is defined with the "description" key.
DIRECTION
A string describing if the parameter acts as "INPUT" or "OUTPUT". In the task template this is defined with the "direction" key. The default is "INPUT".
DISPLAY_NAME
A string for the display name of the parameter that could be used to build a user interface. It can contain spaces and special characters. In the task template this is defined with the "display_name" key. If not set, the value will default to the NAME property's value.
NAME
The name of the parameter which is required on initialization. The parameter’s value can be set and retrieved from the IDLTask using "." dot notation using this name. The name can also be used in the IDLTask::Parameter method to retrieve the parameter object. NAME must be a valid IDL variable name. In the task template this is defined with the "name" key. Use DISPLAY_NAME for a better user interface label.
REQUIRED
A boolean value that indicates whether the parameter is required or not. The default is 0, which allows the parameter to be optional. In the task template this is defined with the "required" key.
TYPE
In the task template when "type" key is defined as DICTIONARY, the IDLParameterDictionary is created and populated with the key/value pairs defined in the template. The TYPE property returned is DICTIONARY.
VALUE
The current value of the parameter. The parameter's VALUE can be set at any time through IDLTask using "." dot notation using the NAME of the parameter, or directly on the parameter object.
IDLParameterDictionary::Dehydrate
The Dehydrate function method transforms the current parameter instance into a Hash containing keys to describe each of its properties. Any property that must conform to the TYPE property will be itself dehydrated by the IDLDehydrate function to ensure they are reduced to primitive form. The return value can be passed into the Hydrate function to clone the parameter instance, or it can be serialized for storage or transmission.
Syntax
Result = IDLParameterDictionary.Dehydrate([ERROR=error])
Return Value
A Hash comprised of IDL primitive values that describes this parameter and all its properties.
Keywords
ERROR
Set this keyword to a named variable that will contain any error message issued during execution. If no error occurs, the ERROR variable will be set to an empty string ('').
When this keyword is not set and an error occurs, the function returns to the caller and execution halts. In this case, the error message is contained within !ERROR_STATE and can be caught using IDL's CATCH routine.
IDLParameterDictionary::Hydrate
The Hydrate static function method takes in a Hash of IDL primitive values and builds a new instance of this parameter class using all the dehydrated properties. It expects all property values to be properly dehydrated. This allows you to dehydrate a parameter and store the primitives, then restore it in a later IDL session.
Syntax
Result = IDLParameterDictionary.Hydrate( dehydratedForm [, ERROR=error])
Return Value
The result is a reference to a new instance of this parameter class.
Arguments
dehydratedForm
The Hash of IDL primitive values describing all of this parameter's properties in dehydrated form, to be transformed into a new instance of this parameter class.
The DICTIONARY properties DEFAULT and VALUE should be defined by a Hash with "elements" and "fold_case" keys. The "fold_case" key is a Boolean value which is used to set the FOLD_CASE property in the output HASH value, and the "elements" key is a Hash with the same keys as the output DICTIONARY value. Each of the keys is associated with a Hash that describes the value for that key in the output DICTIONARY value. That Hash contains a "type" key that will be used for the TYPE keyword when IDLHydrate() is called to rehydrate the value to put in the output DICTIONARY , and a "dehydratedForm" key that stores the dehydrated form of that type.
Keywords
ERROR
Set this keyword to a named variable that will contain any error message issued during execution. If no error occurs, the ERROR variable will be set to an empty string ('').
When this keyword is not set and an error occurs, the function returns to the caller and execution halts. In this case, the error message is contained within !ERROR_STATE and can be caught using IDL's CATCH routine.
IDLParameterDictionary::Validate
This Validate function method returns a Boolean value that indicates whether the Value passed to it is valid for the parameter. If the Value is invalid, then 0 is returned and the ERROR keyword will be populated with information on why the Value is invalid. This method allows the user to test the Value before setting the parameter’s Value and generating an error that must be handled by the user routine.
Syntax
Result = IDLParameterDictionary.Validate( value [, ERROR=error])
Return Value
The result is a Boolean value indicating if the Value is valid for the parameter.
Arguments
Value
The value to test for validity. On successful return this argument will be typecast to the parameter's TYPE.
Keywords
ERROR
Set this keyword to a named variable that will contain any error message issued during execution. If no error occurs, the ERROR variable will be set to an empty string ('').
When this keyword is not set and an error occurs, the function returns to the caller and execution halts. In this case, the error message is contained within !ERROR_STATE and can be caught using IDL's CATCH routine.
Version History
8.5.2 |
Introduced |
8.7 |
Added ALLOW_NULL property
|