FieldBlock Function | |
Return a set-get code block for a field that is identified by its name.
Namespace:
XSharp.RT
Assembly:
XSharp.RT (in XSharp.RT.dll) Version: 2.21
Syntax FUNCTION FieldBlock(
cFieldName AS STRING
) AS Codeblock
public static Codeblock FieldBlock(
string cFieldName
)
Request Example
View SourceParameters
- cFieldName
- Type: String
The name of the field to which the set-get block will refer. When executed with an argument, the code block created by this function assigns the value of the argument to cFieldName.
If omitted, the code block retrieves the value of cFieldName.
Return Value
Type:
Codeblock
A runtime code block (implemented as an object) that, when evaluated, sets (assigns) or gets (retrieves) the value of the given field.
If
cFieldName does not exist in the current work area, FieldBlock() returns NULL_OBJECT.
Remarks
By default, this function operates on the currently selected work area.
It can be made to operate on an unselected work area by specifying
it within an aliased expression
Note that the specified field variable does not have to exist when the code block is created but must exist before the code block is executed.
Tip |
---|
Work area:
The code block returned by FieldBlock() sets or gets the value of the specified field in whatever work area is current when the block is run.
For example, given work areas 1 and 2, both containing field FName:
1DBSetSelect(1)
2_FIELD->FName := "Kate"
3DBSetSelect(2)
4_FIELD->FName := "Cindy"
5cbFName := FieldBlock("FName")
6DBSetSelect(1)
7? EVAL(cbFName)
8DBSetSelect(2)
9? EVAL(cbFName)
Use FieldWBlock() to provide a set-get block for a field in a specific work area.
|
Examples
This example compares FieldBlock() to a code block created using the macro operator. Note that using FieldBlock() avoids the speed and size overhead of the macro operator:
1
2cbSetGet := &("{|SetVal| If(SetVal == NIL,;
3 FName, FName := SetVal)}")
4
5
6
7cbSetGet := FieldBlock("FName")
See Also