Currently, the fields used by your program are defined within the
DEFINE DATA statement in the program itself. It is also possible,
however, to place the field definitions in a local data area (LDA) outside the
program, with the program's DEFINE DATA statement referencing this
local data area by name. For reusability and for a clear application structure,
it is usually better to define fields in data areas outside the programs.
You will now relocate the information from the DEFINE DATA
statement to a local data area. When you have completed the exercises below,
your sample application will consist of the following modules:

This document contains the following exercises:
You will now invoke the data area editor in which you will specify the required fields.
To invoke the data area editor
In the Direct Command window, enter one of the following:
EDIT LOCAL
E L
The data area editor appears. The object type has been set to "Local". This is indicated at the top of the screen.
Press <ESC> to enter command mode
Mem: empty Lib: TUTORIAL Type: LOCAL Bytes: 0 Line: 0 of: 0
C T Comment
* *** Top of Data Area ***
* *** End of Data Area ***
F 1 HELP F 2 CHOICE F 3 QUIT F 4 SAVE F 5 STOW F 6 CHECK
F 7 READ F 8 CLEAR F 9 MEM TYPE F10 GEN F11 FLD TYPE F12 |
By default, the data area editor is in edit mode when you invoke it. To toggle from edit mode to command mode (and vice versa), you press ESC. When you leave the editor, the current mode will be resumed when you open the editor the next time.
You will now define the following fields:
| Level | Name | Format | Length |
|---|---|---|---|
| 1 | #NAME-START |
A | 20 |
| 1 | #NAME-END |
A | 20 |
| 1 | #MARK |
A | 1 |
These are the user-defined variables which you have previously defined
in the DEFINE DATA statement.
To define the data fields
Make sure that the first entry, which indicates the top of the data area, is selected in the editor.
Tip:
If it is not possible to move the cursor and thus to highlight a
line, you are in command mode. In this mode, the command line is shown at the
top of the screen. Press ESC to switch to edit mode.
Enter the following line command in the first column of the selected line:
I
You need not press ENTER.
The following window appears.
+-----------------------+ ¦ D Data Field ¦ ¦ B Block ¦ ¦ C Constant ¦ ¦ H Handle ¦ ¦ S Structure ¦ ¦ * Comment ¦ +-----------------------+ |
Choose Data Field.
The Data Field Definition window appears.
+-------------------- Data Field Definition ---------------------+ ¦ Level: 1 ¦ ¦ Field Name: ¦ ¦ Field Format: ¦ ¦ Field Length: ¦ ¦ Arraydefinition: ¦ ¦ Edit Mask: ¦ ¦ ¦ ¦ Header Definition: ¦ ¦ ¦ ¦ Initialization: ¦ ¦ Value Clause: ¦ ¦ Optional Param: N ¦ ¦ Comment: ¦ +----------------------------------------------------------------+ |
Specify all required information for the first field
(#NAME-START) as listed in the above table. Use the arrow keys to
move from one field to the next.
When all information for this field has been specified, press ENTER to save this information.
The Data Field Definition window remains open. The input fields are empty again and you can define a new data field.
Specify all required information for the remaining fields
(#NAME-END and #MARK) as described above.
When all fields have been added, press ESC.
The fields you have defined are now shown in the editor.
Press <ESC> to enter command mode
Mem: Lib: TUTORIAL Type: LOCAL Bytes: 291 Line: 3 of: 3
C T L Name of Datafield F Length Index/Comment M
* *** Top of Data Area ***
1 #NAME-START A 20
1 #NAME-END A 20
1 #MARK A 1
* *** End of Data Area ***
F 1 HELP F 2 CHOICE F 3 QUIT F 4 SAVE F 5 STOW F 6 CHECK
F 7 READ F 8 CLEAR F 9 MEM TYPE F10 GEN F11 FLD TYPE F12 |
Tip:
If you notice that you have made a mistake in a field definition,
you can use the line command E to edit the selected
field or the line command D to delete the selected
field.
You will now import the same data fields which you have previously
defined in the program's DEFINE DATA statement. The fields are
read directly from a Natural data view into the data area editor. A data view
references database fields defined in a data definition module (DDM).
In the data area editor, the imported data fields will be inserted below the currently selected data field.
To import data fields from a DDM
Enter the following line command in the first column of
the #MARK line.
V
The View Definition window appears.
Press <ESC> to enter command mode
Mem: Lib: TUTORIAL Type: LOCAL Bytes: 291 Line: 3 of: 3
C T L Name of Datafield F Length Index/Comment M
* *** Top of Data Area ***
1 #NAME-START A 20
1 #NAME-END A 20
V 1 #MARK A 1
* *** End of Data Area ***
+------------------- View Definition -------------------+
¦Name of View: ¦
¦Name of DDM: ¦
¦Comment: ¦
+-------------------------------------------------------+
F 1 HELP F 2 CHOICE F 3 QUIT F 4 SAVE F 5 STOW F 6 CHECK
F 7 READ F 8 CLEAR F 9 MEM TYPE F10 GEN F11 FLD TYPE F12 |
Enter the following information and press ENTER:
+------------------- View Definition -------------------+ ¦Name of View: EMPLOYEES-VIEW ¦ ¦Name of DDM: EMPLOYEES ¦ ¦Comment: ¦ +-------------------------------------------------------+ |
A window appears showing the fields of the specified DDM.
Press <ESC> to enter command mode
Mem: Lib: TUTORIAL Type: LOCAL Bytes: 291 Line: 3 of: 3
C T L Name of Datafield F Length Index/Comment M
* *** Top of Data Area ***
1 #NAME-START A 20
1 #NAME-END A 20
V 1 #MARK A 1
* *** End of Data Area ***
+------------------------------- DDM: EMPLOYEES -------------------------------+
¦ 1 AA PERSONNEL-ID A 8 D ¦
¦ G 1 AB FULL-NAME ¦
¦ 2 AC FIRST-NAME A 20 N ¦
¦ 2 AD MIDDLE-I A 1 N ¦
¦ 2 AE NAME A 20 D ¦
¦ 1 AD MIDDLE-NAME A 20 N ¦
+------------------------------------------------------------------------------+
HD=PERSONNEL/ID
F 1 HELP F 2 CHOICE F 3 QUIT F 4 SAVE F 5 STOW F 6 CHECK
F 7 READ F 8 CLEAR F 9 MEM TYPE F10 GEN F11 FLD TYPE F12 |
Mark the following fields by entering an "X" in the first column:
PERSONNEL-ID
FULL-NAME
NAME
DEPT
LEAVE-DATA
LEAVE-DUE
Use the arrow keys to scroll through the DDM.
Note:
The field PERSONNEL-ID will be used later when you
create the subprogram.
After you have marked all required fields, press ENTER.
The local data area should now look as follows (use the arrow keys to scroll to the top of the data area):
Press <ESC> to enter command mode
Mem: Lib: TUTORIAL Type: LOCAL Bytes: 970 Line: 0 of: 10
C T Comment
* *** Top of Data Area ***
1 #NAME-START A 20
1 #NAME-END A 20
1 #MARK A 1
V 1 EMPLOYEES-VIEW EMPLOYEES
2 PERSONNEL-ID A 8
G 2 FULL-NAME
3 NAME A 20
2 DEPT A 6
G 2 LEAVE-DATA
3 LEAVE-DUE N 2
* *** End of Data Area ***
F 1 HELP F 2 CHOICE F 3 QUIT F 4 SAVE F 5 STOW F 6 CHECK
F 7 READ F 8 CLEAR F 9 MEM TYPE F10 GEN F11 FLD TYPE F12 |
The T column indicates the type of the variable. The view is indicated by a "V" and each group is indicated by a "G".
Press ESC to enter command mode.
Stow the local data area and name it "LDA01".
STOW LDA01
Once a local data area has been stowed, it can be referenced by a Natural program.
You will now change the DEFINE DATA statement your program
so that it uses the local data area that you have just defined.
To use the local data area in your program
Return to the program editor by entering the following in the command line of the data area editor.
E PGM01
In the DEFINE DATA statement, delete all variables
between LOCAL and END-DEFINE
(use the line command D).
Add a reference to your local data area by modifying the
LOCAL line as follows:
LOCAL USING LDA01
Your program should now look as follows:
DEFINE DATA
LOCAL USING LDA01
END-DEFINE
*
RP1. REPEAT
*
INPUT USING MAP 'MAP01'
*
IF #NAME-START = '.' THEN
ESCAPE BOTTOM (RP1.)
END-IF
*
IF #NAME-END = ' ' THEN
MOVE #NAME-START TO #NAME-END
END-IF
*
RD1. READ EMPLOYEES-VIEW BY NAME
STARTING FROM #NAME-START
ENDING AT #NAME-END
*
IF LEAVE-DUE >= 20 THEN
PERFORM MARK-SPECIAL-EMPLOYEES
ELSE
RESET #MARK
END-IF
*
DISPLAY NAME 3X DEPT 3X LEAVE-DUE 3X '>=20' #MARK
*
END-READ
*
IF *COUNTER (RD1.) = 0 THEN
REINPUT 'No employees meet your criteria.'
END-IF
*
END-REPEAT
*
DEFINE SUBROUTINE MARK-SPECIAL-EMPLOYEES
MOVE '*' TO #MARK
END-SUBROUTINE
*
END
Run the program.
To confirm that the results are the same as before (when the
DEFINE DATA statement did not reference a local data area), enter
"JONES" as the starting name and press
ENTER.
To return to the program editor, enter
EDIT at the MORE prompt.
Stow the program.
You can now proceed with the next exercises: Global Data Areas.