The most of compilers report error messages for incorrect program. Here the package `errors' which serves to output one-pass or multi-pass compiler messages of various modes (errors, warnings, fatal, system errors and appended messages) in Unix style or for traditional listing is suggested. The package also permits adequate error reporting for included files.
The package uses packages `vlobject', `objstack', `position' which use package `allocate'. Therefore package `position' have to be initiated before any work with this package. The interface part of the package is file `errors.h'. The implementation part is file `errors.cpp'. The maximum length of generated error message is suggested to be not greater then `MAX_ERROR_MESSAGE_LENGTH'. The default value (150) of this macro can be redefined with corresponding C++ compiler option `-DMAX_ERROR_MESSAGE_LENGTH=...' during compilation of file `errors.cpp'. The interface contains only one class `errors'. The class has the following members:
        `unsigned int number_of_errors (void)'
        `unsigned int number_of_warnings (void)'
        
has value which is maximum number of errors which will be fixed. If an error is fixed with number equals to `maximum_number_of_errors' then special fatal error `fatal error -- too many errors' with position of given error is fixed instead of the error. And all following errors are ignored. Zero value of the variable means that the special fatal error will never fixed.
        `void fatal_error_function (void)'
        
        `errors (int immediate_output_flag)'
        
        `~errors (void)'
        
        `void output (void)'
        
        `void error (int fatal_error_flag, position_t
                     position, const char *format, ...)'
        
           error (1, current_position, "fatal error - no memory");
        
        `void warning (position_t position, const char *format, ...)'
        
        `void append_message (position_t position,
                              const char *format, ...)'
        
For example, this function may be used for generation of messages of type
              `<file>:<line>:<position-1>: repeated declaration'
        
              `<file>:<line>:<position-1>: previous declaration'.
        
        `void system_error (int fatal_error_flag,
                            position_t position,
                            const char *format, ...)'
        
             system_error  (1, current_position,
                            "fatal error - %s:", new_file_name);
        
        `void default_output_error_function
              (int appended_message_flag, position_t position,
               const char *message)'
        
By default the function is oriented to output in Unix style according to GNU standard. To output a listing the function `output_error_function' should be changed. The default function output message in the following formats:
  MESSAGE                              (NULL file name)
  FILE_NAME:1: MESSAGE                 (zero line number)
  FILE_NAME:LINE_NUMBER: MESSAGE       (zero column number)
  FILE_NAME:LINE_NUMBER:COLUMN_NUMBER-1: MESSAGE  (all other cases)