The report routine implements the body of a report, with formatting instructions.
[PUBLIC|PRIVATE] REPORT report-name (argument-list) [ define-section ] [ output-section ] [ sort-section ] [ format-section ] END REPORT
DEFINE variable-definition [,...]
OUTPUT [ REPORT TO { SCREEN | PRINTER | [ FILE ] filename | PIPE program [ IN FORM MODE | IN LINE MODE ] } ] [ [ WITH ] [ LEFT MARGIN m-left ] [ RIGHT MARGIN m-right] [ TOP MARGIN m-top ] [ BOTTOM MARGIN m-bottom ] [ PAGE LENGTH m-length ] [ TOP OF PAGE c-top] ]
ORDER [ EXTERNAL ] BY report-variable [,...]
FORMAT EVERY ROWor:
FORMAT control-block [ report-only-fgl-statement | sql-statement | report-statement ] [...] [...]
{ [ FIRST ] PAGE HEADER | ON EVERY ROW | BEFORE GROUP OF report-variable | AFTER GROUP OF report-variable | PAGE TRAILER | ON LAST ROW }
The report definition formats input records. Like the FUNCTION or MAIN statement, it is a program block that can be the scope of local variables. It is not, however, a function; it is not reentrant, and CALL cannot invoke it. The report definition receives data from its driver in sets called input records. These records can include program records, but other data types are also supported. Each input record is formatted and printed as specified by control blocks and statements within the report definition. Most statements and functions can be included in a report definition, and certain specialized statements and operators for formatting output can appear only in a report definition.
Like MAIN or FUNCTION, the report definition must appear outside any other program block. It must begin with the REPORT statement and must end with the END REPORT keywords.
Some statements are prohibited in a REPORT routine control block. For example, it is not possible to use CONSTRUCT, INPUT, DEFER, DEFINE, REPORT, RETURN instructions in a control block of a report.
By default, report routines are public; They can be called by any other module of the program. If a report routine is only used by the current module, you may want to hide that routine to other modules, to make sure that it will not be called by mistake. To keep a report routine local to the module, add the PRIVATE keyword before the report header. Private report routines are only hidden to external modules, all function of the current module can still call local private report routines.
The define section declares the data types of local variables used within the report, and of any variables (the input records) that are passed as arguments to the report by the calling statement. Reports without arguments or local variables do not require a DEFINE section.
The output-section can set margin and page size values, and can also specify where to send the formatted output. Output from the report consists of successive pages, each containing a fixed number of lines whose margins and maximum number of characters are fixed.
The sort-section specifies how the rows have to be sorted. The specified sort order determines the order in which the runtime system processes any GROUP OF control blocks in the FORMAT section.
The format-section is required. It specifies the appearance of the report, including page headers, page trailers, and aggregate functions of the data. It can also contain control blocks that specify actions to take before or after specific groups of rows are processed. (Alternatively, it can produce a default report by only specifying FORMAT EVERY ROW).