The first record in every variable structure file is a system record called
the file header. This is normally 128 bytes in length and takes the following
form:
  
 
| Offset | Size | Description | 
 
| 0 | 4 | Length of the file header. The first 4 bits are always set to 3 (0011 in
binary) indicating that this is a system record. The remaining bits contain
the length of the file header record. If the maximum record length is less
than 4095 bytes, the length is 126 and is held in the next 12 bits; otherwise
it is 124 and is held in the next 28 bits. Hence, in a file where the maximum
record length is less than 4095 bytes, this field contains x"30 7E 00 00".
Otherwise, this field contains x"30 00 00 7C". | 
 
| 4 | 2 | Database sequence number, used by add-on products. | 
 
| 6 | 2 | Integrity flag. Indexed files only. If this is non-zero when the header is
read, it indicates that the file is corrupt. | 
 
| 8 | 14 | Creation date and time in YYMMDDHHMMSSCC format. Indexed files only. | 
| 22 | 14 | Reserved. | 
 
| 36 | 2 | Reserved. Value 62 decimal; x"00 3E". | 
 
| 38 | 1 | Not used. Set to zeros. | 
 
| 39 | 1 | Organization: 
 
| 1 | Sequential |   
| 2 | Indexed |   
| 3 | Relative |  | 
 
| 40 | 1 | Not used. Set to zeros. | 
 
| 41 | 1 | Data compression routine number: 
 
| 0 | No compression |   
| 1 | CBLDC001 |   
| 2-127 | Reserved for internal use |   
| 128-255 | User-defined compression routine number |  | 
 
| 42 | 1 | Not used. Set to zeros. | 
 
| 43 | 1 | Indexed files only - type of indexed file. See the topic Types of Indexed
File. | 
 
| 44 | 4 | Reserved. | 
 
| 48 | 1 | Recording mode: 
 
| 0 | Fixed format |   
| 1 | Variable format |  For indexed files, the recording mode field of the .idx file takes precedence. | 
| 49 | 5 | Not used. Set to zeros. | 
 
| 54 | 4 | Maximum record length. Example: with a maximum record of length 80 characters,
this field will contain x"00 00 00 50". | 
 
| 58 | 4 | Minimum record length. Example: with a minimum record length of 2 characters,
this field will contain x"00 00 00 02". | 
 
| 62 | 46 | Not used. Set to zeros. | 
 
| 108 | 4 | Version and build data for the indexed file handler creating the file. Indexed
files only. | 
 
| 112 | 16 | Not used. Set to zeros. |