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.