| Previous | Contents | Index | 
Several variations to the basic report format are discussed in the next 
sections.
10.10.1 Printing More Than One Logical Line on a Single Physical Line
When your report has only a few columns, you can print several logical lines on one physical line. If you were to print names and addresses on four-up self-sticking multilabel forms, you would print the form left to right and top to bottom, as shown in Figure 10-20 and Example 10-11. To print four-up self-sticking labels, you must format each logical line with four input records.
However, if the columns must be sorted by column, the task becomes more difficult. The last line at the end of the first column is continued at the top of the second column of the same page, indented to the right, and so forth, as shown in Figure 10-21 and Example 10-12. Example 10-12 defines a table containing all data to appear on the page. It reads the input records, stores the data in the table as it is to appear on the page, prints the contents of the table and then fills spaces. When it reaches the end of file, the remaining entries in the table are automatically blank. You can extend this technique to print any number of logical lines on a single physical line.
Figure 10-20 Printing Labels Four-Up
 
| Example 10-11 Printing Labels Four-Up | |||||
|---|---|---|---|---|---|
| 
IDENTIFICATION DIVISION. 
PROGRAM-ID. REP02. 
ENVIRONMENT DIVISION. 
INPUT-OUTPUT SECTION. 
FILE-CONTROL. 
    SELECT INPUT-FILE  ASSIGN TO "LABELS.DAT". 
    SELECT REPORT-FILE ASSIGN TO "LABELS.REP". 
DATA DIVISION. 
FILE SECTION. 
FD  INPUT-FILE. 
01  INPUT-RECORD. 
    02  INPUT-NAME      PIC X(20). 
    02  INPUT-ADDRESS   PIC X(15). 
    02  INPUT-CITY      PIC X(10). 
    02  INPUT-STATE     PIC XX. 
    02  INPUT-ZIP       PIC 99999. 
FD  REPORT-FILE. 
01  REPORT-RECORD       PIC X(132). 
WORKING-STORAGE SECTION. 
01  LABELS-TABLE. 
        03  NAME-LINE. 
            05  LINE-1 OCCURS 4 TIMES INDEXED BY INDEX-1. 
                07  LABEL-NAME       PIC X(20). 
                07  FILLER           PIC X(10). 
        03  ADDRESS-LINE. 
            05  LINE-2 OCCURS 4 TIMES INDEXED BY INDEX-2. 
                07  LABEL-ADDRESS    PIC X(15). 
                07  FILLER           PIC X(15). 
        03  CSZ-LINE. 
            05  LINE-3 OCCURS 4 TIMES INDEXED BY INDEX-3. 
                07  LABEL-CITY       PIC X(10). 
                07  FILLER           PIC XXXX. 
                07  LABEL-STATE      PIC XX. 
                07  FILLER           PIC XXXX. 
                07  LABEL-ZIP        PIC 99999. 
                07  FILLER           PIC XXXXX. 
01  END-OF-FILE                      PIC X. 
PROCEDURE DIVISION. 
A000-BEGIN. 
    OPEN INPUT  INPUT-FILE 
         OUTPUT REPORT-FILE. 
    MOVE SPACES TO LABELS-TABLE. 
    SET INDEX-1, INDEX-2, INDEX-3 TO 1. 
    PERFORM A100-READ-INPUT UNTIL END-OF-FILE = "Y". 
A050-WRAP-UP. 
    IF LABEL-NAME(1) IS NOT EQUAL TO SPACES 
       PERFORM A300-PRINT-FOUR-LABELS. 
A050-END-OF-JOB. 
    CLOSE INPUT-FILE 
          REPORT-FILE. 
    DISPLAY "END OF JOB". 
    STOP RUN. 
* 
A100-READ-INPUT. 
    READ INPUT-FILE AT END MOVE "Y" TO END-OF-FILE. 
    IF END-OF-FILE = "Y" NEXT SENTENCE 
       ELSE PERFORM A200-GENERATE-TABLE. 
* 
A200-GENERATE-TABLE. 
    MOVE INPUT-NAME     TO LABEL-NAME(INDEX-1) 
    MOVE INPUT-ADDRESS  TO LABEL-ADDRESS(INDEX-2) 
    MOVE INPUT-CITY     TO LABEL-CITY(INDEX-3) 
    MOVE INPUT-STATE    TO LABEL-STATE(INDEX-3) 
    MOVE INPUT-ZIP      TO LABEL-ZIP(INDEX-3) 
    IF INDEX-1 = 4 PERFORM A300-PRINT-FOUR-LABELS 
       ELSE        SET INDEX-1, INDEX-2, INDEX-3 UP BY 1. 
* 
A300-PRINT-FOUR-LABELS. 
    WRITE REPORT-RECORD FROM NAME-LINE AFTER ADVANCING 3. 
    WRITE REPORT-RECORD FROM ADDRESS-LINE AFTER ADVANCING 1. 
    WRITE REPORT-RECORD FROM CSZ-LINE AFTER ADVANCING 1. 
    MOVE SPACES TO LABELS-TABLE. 
    SET INDEX-1, INDEX-2, INDEX-3 TO 1. 
 | 
Figure 10-21 Printing Labels Four-Up in Sort Order
 
| Example 10-12 Printing Labels Four-Up in Sort Order | |||||
|---|---|---|---|---|---|
| 
IDENTIFICATION DIVISION. 
PROGRAM-ID. REP03. 
ENVIRONMENT DIVISION.        
INPUT-OUTPUT SECTION. 
FILE-CONTROL. 
    SELECT INPUT-FILE  ASSIGN TO "LABELS.DAT". 
    SELECT REPORT-FILE ASSIGN TO "LABELS.REP". 
DATA DIVISION. 
FILE SECTION. 
FD  INPUT-FILE. 
01  INPUT-RECORD. 
    02  INPUT-NAME      PIC X(20). 
    02  INPUT-ADDRESS   PIC X(15). 
    02  INPUT-CITY      PIC X(10). 
    02  INPUT-STATE     PIC XX. 
    02  INPUT-ZIP       PIC 99999. 
FD  REPORT-FILE. 
01  REPORT-RECORD       PIC X(132). 
WORKING-STORAGE SECTION. 
01  LABELS-TABLE. 
    03  FOUR-UP OCCURS 6 TIMES INDEXED BY ROW-INDEX. 
        04  NAME-LINE. 
            05  LINE-1 OCCURS 4 TIMES INDEXED BY NAME-INDEX. 
                07  LABEL-NAME       PIC X(20). 
                07  FILLER           PIC X(10). 
        04  ADDRESS-LINE. 
            05  LINE-2 OCCURS 4 TIMES INDEXED BY ADDRESS-INDEX. 
                07  LABEL-ADDRESS    PIC X(15). 
                07  FILLER           PIC X(15). 
        04  CSZ-LINE. 
            05  LINE-3 OCCURS 4 TIMES INDEXED BY CSZ-INDEX. 
                07  LABEL-CITY       PIC X(10). 
                07  FILLER           PIC XXXX. 
                07  LABEL-STATE      PIC XX. 
                07  FILLER           PIC XXXX. 
                07  LABEL-ZIP        PIC 99999. 
                07  FILLER           PIC XXXXX. 
01  END-OF-FILE                      PIC X. 
PROCEDURE DIVISION. 
A000-BEGIN. 
    OPEN INPUT  INPUT-FILE 
         OUTPUT REPORT-FILE. 
    MOVE SPACES TO LABELS-TABLE. 
    SET ROW-INDEX, NAME-INDEX, ADDRESS-INDEX, CSZ-INDEX TO 1. 
    PERFORM A100-READ-INPUT UNTIL END-OF-FILE = "Y". 
A050-WRAP-UP. 
    IF LABEL-NAME(1, 1) IS NOT EQUAL TO SPACES 
       PERFORM A300-PRINT-PAGE-OF-LABELS VARYING ROW-INDEX 
               FROM 1 BY 1 UNTIL ROW-INDEX IS GREATER THAN 6. 
A050-END-OF-JOB. 
    CLOSE INPUT-FILE 
          REPORT-FILE. 
    DISPLAY "END OF JOB". 
    STOP RUN. 
A100-READ-INPUT. 
    READ INPUT-FILE AT END MOVE "Y" TO END-OF-FILE. 
    IF END-OF-FILE = "Y" NEXT SENTENCE 
       ELSE PERFORM A200-GENERATE-LABELS. 
A200-GENERATE-LABELS. 
    MOVE INPUT-NAME     TO LABEL-NAME(ROW-INDEX, NAME-INDEX) 
    MOVE INPUT-ADDRESS  TO LABEL-ADDRESS(ROW-INDEX, ADDRESS-INDEX) 
    MOVE INPUT-CITY     TO LABEL-CITY(ROW-INDEX, CSZ-INDEX) 
    MOVE INPUT-STATE    TO LABEL-STATE(ROW-INDEX, CSZ-INDEX) 
    MOVE INPUT-ZIP      TO LABEL-ZIP(ROW-INDEX, CSZ-INDEX) 
    IF ROW-INDEX = 6 AND NAME-INDEX = 4 
       PERFORM A300-PRINT-PAGE-OF-LABELS VARYING ROW-INDEX 
               FROM 1 BY 1 UNTIL ROW-INDEX IS GREATER THAN 6 
       MOVE SPACES TO LABELS-TABLE 
       SET ROW-INDEX, NAME-INDEX, ADDRESS-INDEX, CSZ-INDEX TO 1 
     ELSE 
       PERFORM A210-UPDATE-INDEXES. 
A210-UPDATE-INDEXES. 
    IF ROW-INDEX =  6 SET ROW-INDEX      TO 1 
                      SET NAME-INDEX 
                          ADDRESS-INDEX 
                          CSZ-INDEX   UP BY 1 
       ELSE 
               SET ROW-INDEX UP BY 1. 
A300-PRINT-PAGE-OF-LABELS. 
    WRITE REPORT-RECORD FROM NAME-LINE(ROW-INDEX) 
          AFTER ADVANCING 3. 
    WRITE REPORT-RECORD FROM ADDRESS-LINE(ROW-INDEX) 
          AFTER ADVANCING 1. 
    WRITE REPORT-RECORD FROM CSZ-LINE(ROW-INDEX) 
          AFTER ADVANCING 1. 
 | 
The group indicating process greatly improves a report's readability where long sequences of entries have some element in common. You print the element once, then leave it blank for subsequent lines, as long as there is no change in that element. For example, if your sample file's sort sequence is State (major key) and City (minor key), you get sequences like those in Table 10-2.
| Without Group Indicating | With Group Indicating | ||||
|---|---|---|---|---|---|
| STATE | CITY | STORE NUMBER | STATE | CITY | STORE NUMBER | 
| Arizona | Grand Canyon | 111111 | Arizona | Grand Canyon | 111111 | 
| Arizona | Grand Canyon | 123456 | 123456 | ||
| Arizona | Grand Canyon | 222222 | 222222 | ||
| Arizona | Tucson | 333333 | Arizona | Tucson | 333333 | 
| Arizona | Tucson | 444444 | 444444 | ||
| Arizona | Tucson | 555555 | 555555 | ||
| Massachusetts | Maynard | 111111 | Massachusetts | Maynard | 111111 | 
| Massachusetts | Maynard | 222222 | 222222 | ||
| Massachusetts | Maynard | 333333 | 333333 | ||
| Massachusetts | Maynard | 444444 | 444444 | ||
| Massachusetts | Tewksbury | 111111 | Massachusetts | Tewksbury | 111111 | 
| Massachusetts | Tewksbury | 222222 | 222222 | ||
| New Hampshire | Manchester | 111111 | New Hampshire | Manchester | 111111 | 
| New Hampshire | Manchester | 222222 | 222222 | ||
| New Hampshire | Merrimack | 333333 | New Hampshire | Merrimack | 333333 | 
| New Hampshire | Merrimack | 444444 | 444444 | ||
| New Hampshire | Merrimack | 555555 | 555555 | ||
| New Hampshire | Nashua | 666666 | New Hampshire | Nashua | 666666 | 
If you need more columns than physically can fit on a page, you can do the following:
A report that must include totals at the top of the page before the detail lines has three solutions as follows:
The examples in this section apply only to printers that support overprinting.
Sometimes you must underline a column of numbers to denote a total and also underline the total to highlight it:
| 1234 1122 ---- 2356 ==== | 
To print a single underline, use the underscore character and suppress line spacing. For example:
| 
WRITE PRINT-LINE FROM SINGLE-UNDERLINE-TOTAL 
                 BEFORE ADVANCING 0 LINES. 
 | 
This overprints the underscore (_) on the previous line, underlining the item: 1122. Use the equal sign (=) to simulate double underlines. Note that you must write the equal signs on the next line. For example:
| 
WRITE PRINT-LINE FROM DOUBLE-UNDERLINE-TOTAL 
                 AFTER ADVANCING 1 LINE. 
 | 
The examples in this section apply only to printers that support overprinting.
To bold an entire line in a report:
For example:
| WRITE PRINT-LINE FROM TOTAL-LINE BEFORE ADVANCING 0 LINES. WRITE PRINT-LINE FROM TOTAL-LINE BEFORE ADVANCING 0 LINES. WRITE PRINT-LINE FROM TOTAL-LINE BEFORE ADVANCING 0 LINES. WRITE PRINT-LINE FROM TOTAL-LINE. | 
This example produces a darker image in the report. You can use similar statements for characters and words, as well as complete lines. To bold only a word or only a character within a line, you must:
For example:
| 
    WRITE PRINT-LINE FROM TOTAL-LINE BEFORE ADVANCING 0 LINES. 
* 
* Move spaces over the items in the source print line (TOTAL-LINE) 
* that are not to be bolded 
* 
    MOVE SPACES TO ... 
    WRITE PRINT-LINE FROM TOTAL-LINE BEFORE ADVANCING 0 LINES. 
    WRITE PRINT-LINE FROM TOTAL-LINE BEFORE ADVANCING 0 LINES. 
    WRITE PRINT-LINE FROM TOTAL-LINE. 
 | 
ACCEPT and DISPLAY statements are used to make low-volume data available to specified devices. You will find the following information useful:
The COBOL language provides two statements, ACCEPT and DISPLAY, for low-volume I/O operations. The ACCEPT and DISPLAY statements transfer data between your program and the standard input and output devices. If you do not use the FROM or UPON phrases, or an environment variable, the default device for ACCEPT is the keyboard and the default device for DISPLAY is the terminal screen.
The FROM or UPON phrases refer to mnemonic names that you can define in the Environment Division SPECIAL-NAMES paragraph. You define a mnemonic name by equating it to a COBOL implementor name; for example, the following clause equates STATUS-REPORT to the device LINE-PRINTER:
| LINE-PRINTER IS STATUS-REPORT | 
You can then use the mnemonic name in a DISPLAY statement:
| DISPLAY "File contains " REC-COUNT UPON STATUS-REPORT. | 
The COBOL implementor names in the SPECIAL-NAMES paragraph refer to special Compaq COBOL environment variables or logical names. Environment variables or logical names do not always represent physical devices.
On the Tru64 UNIX operating system, you can assign an environment variable to a file name as follows:
| % setenv COBOL_LINEPRINTER status.lis <> | 
On OpenVMS, you can assign a logical name to a file specification using the ASSIGN command (or the DEFINE command, with the arguments in reverse order):
| $ ASSIGN [ALLSTATUS]STATUS.LIS COB$LINEPRINTER <> | 
If you use an environment variable or a logical name, you must define it appropriately for the ACCEPT or DISPLAY statement to succeed.
On OpenVMS, when you run an application, if input and output are both directed to terminals, they must be directed to the same terminal. If input and output are directed to different terminals, the output terminal is used and the input terminal is ignored. <>
For more information on the logical names or environment variables and the mnemonic names, refer to the SPECIAL-NAMES section in the Environment Division chapter in the Compaq COBOL Reference Manual.
On OpenVMS, the ACCEPT statement transfers data from the input device to a data item. If you do not use the FROM phrase, the system uses the logical name COB$INPUT if it is defined, otherwise SYS$INPUT. If you use the FROM phrase, it uses the logical name associated with the mnemonic-name in the FROM clause. <>
On Tru64 UNIX, the ACCEPT statement transfers data from the input device to a data item. If you do not use the FROM phrase, the system uses the environment variable COBOL_INPUT if it is defined, or stdin if COBOL_INPUT is not otherwise defined. If you use the FROM phrase, the system uses the environment variable associated with the mnemonic-name in the FROM clause. <>
The following example illustrates the FROM phrase used in conjunction with ACCEPT:
| 
SPECIAL-NAMES. 
    CARD-READER IS WHATS-THE-NAME 
    . 
    . 
    . 
PROCEDURE DIVISION. 
    . 
    . 
    . 
    ACCEPT PARAMETER-AREA FROM WHATS-THE-NAME. 
 | 
On OpenVMS, the DISPLAY statement transfers the contents of data items and literals to the output device. If you do not use the UPON phrase, the system uses the logical name COB$OUTPUT if it is defined, or SYS$OUTPUT if it is not defined. If you use the UPON phrase, the system uses the logical name associated with the mnemonic-name in the FROM clause. <>
On Tru64 UNIX, the DISPLAY statement transfers the contents of data items and literals to the output device. If you do not use the UPON phrase, the system uses the environment variable COBOL_OUTPUT if it is defined, or stdout if it is not defined. If you use the UPON phrase, the system uses the environment variable associated with the mnemonic-name in the UPON clause.
The following example illustrates the UPON phrase used in conjunction with DISPLAY:
| 
SPECIAL-NAMES.  
    LINE-PRINTER IS ERROR-LOG 
    .  
    .  
    .  
PROCEDURE DIVISION.  
    .  
    .  
    .  
    DISPLAY ERROR-COUNT, "  phase 2 errors, ", ERROR-MSG UPON ERROR-LOG.  
 | 
The extended Compaq COBOL options to the ACCEPT and DISPLAY statements provide video forms features. You can develop video forms on VT100 and later series terminals and faithful emulators and write your application without regard to the type of terminal on which the application will eventually run. You can also run your forms application in the terminal emulator window of a workstation. 1
Using the extended forms of the ACCEPT and DISPLAY statements, you can design video forms to:
Figure 11-1 is a sample form created by a Compaq COBOL program. It is for entry of employee information into a master file. This program prompts the user to type in data. Then the program writes it to the master file and displays a new form.
Figure 11-1 Video Form to Gather Information for a Master File Record
 
| The final appearance of screens depends upon the setting of your system display setup properties (for example, dark on light, or light on dark). The following figures are representative only. | 
For information on differences between the Compaq COBOL and the Compaq COBOL for OpenVMS VAX implementations of screen management, see Appendix B. For complete reference information on the ACCEPT and DISPLAY statements, including syntax, refer to the Compaq COBOL Reference Manual.
Designing Your Form  with ACCEPT and DISPLAY Options 
When you design a video form, you can use the ACCEPT and DISPLAY options to do the following:
The remainder of this chapter describes these topics.
| 1 Compaq COBOL does not provide mouse or split screen support. | 
| Previous | Next | Contents | Index |