// $Id: error.cpp,v 1.17 1999/03/10 19:59:21 shields Exp $
copyright notice

#include "config.h"
#include <sys/stat.h>
#include "unicode.h"
#include "error.h"
#include "control.h"
#include "semantic.h"
#include "ast.h"

unsigned char SemanticError::warning[SemanticError::_num_kinds] = { 0 };
void (*SemanticError::print_message[SemanticError::_num_kinds]) (SemanticError::ErrorInfo &, LexStream *, Control &) = { NULL };

SemanticError::SemanticError(Control &control_, FileSymbol *file_symbol) : control(control_),
                                                                           lex_stream(file_symbol -> lex_stream),

                                                                           buffer(1024),
                                                                           error(512),
                                                                           clone_count(0),
                                                                           num_errors(0),
                                                                           num_warnings(0)
{}

//
// This procedure is invoked by an JIKES PARSER or a semantic
// routine to process an error message.  The JIKES parser always
// passes the value 0 to msg_level to indicate an error.
// This routine simply stores all necessary information about
// the message into an array: error.
//
void SemanticError::Report(SemanticErrorKind msg_code,
                           LexStream::TokenIndex left_token,
                           LexStream::TokenIndex right_token,
                           wchar_t *insert1,
                           wchar_t *insert2,
                           wchar_t *insert3,
                           wchar_t *insert4,
                           wchar_t *insert5,
                           wchar_t *insert6,
                           wchar_t *insert7,
                           wchar_t *insert8,
                           wchar_t *insert9)
{
    if (clone_count > 0) // do not report errors detected while processing a clone !!!
        return;

    int i = error.NextIndex();

    if (warning[msg_code] > 0)
         num_warnings++;
    else num_errors++;

    error[i].msg_code = msg_code;

    int total_length = 0,
        length1,
        length2,
        length3,
        length4,
        length5,
        length6,
        length7,
        length8,
        length9;

    if (insert1)
    {
        length1 = wcslen(insert1);
        total_length += (length1 + 1);
    }
    else error[i].insert1 = NULL;

    if (insert2)
    {
        length2 = wcslen(insert2);
        total_length += (length2 + 1);
    }
    else error[i].insert2 = NULL;

    if (insert3)
    {
        length3 = wcslen(insert3);
        total_length += (length3 + 1);
    }
    else error[i].insert3 = NULL;

    if (insert4)
    {
        length4 = wcslen(insert4);
        total_length += (length4 + 1);
    }
    else error[i].insert4 = NULL;

    if (insert5)
    {
        length5 = wcslen(insert5);
        total_length += (length5 + 1);
    }
    else error[i].insert5 = NULL;

    if (insert6)
    {
        length6 = wcslen(insert6);
        total_length += (length6 + 1);
    }
    else error[i].insert6 = NULL;

    if (insert7)
    {
        length7 = wcslen(insert7);
        total_length += (length7 + 1);
    }
    else error[i].insert7 = NULL;

    if (insert8)
    {
        length8 = wcslen(insert8);
        total_length += (length8 + 1);
    }
    else error[i].insert8 = NULL;

    if (insert9)
    {
        length9 = wcslen(insert9);
        total_length += (length9 + 1);
    }
    else error[i].insert9 = NULL;

    if (total_length > 0)
    {
        wchar_t *ptr = new wchar_t[total_length];
        buffer.Next() = ptr;

        if (insert1)
        {
            memmove(ptr, insert1, length1 * sizeof(wchar_t));
            error[i].insert1 = ptr;
            ptr += length1;
            *ptr++ = U_NULL;
        }

        if (insert2)
        {
            memmove(ptr, insert2, length2 * sizeof(wchar_t));
            error[i].insert2 = ptr;
            ptr += length2;
            *ptr++ = U_NULL;
        }

        if (insert3)
        {
            memmove(ptr, insert3, length3 * sizeof(wchar_t));
            error[i].insert3 = ptr;
            ptr += length3;
            *ptr++ = U_NULL;
        }

        if (insert4)
        {
            memmove(ptr, insert4, length4 * sizeof(wchar_t));
            error[i].insert4 = ptr;
            ptr += length4;
            *ptr++ = U_NULL;
        }

        if (insert5)
        {
            memmove(ptr, insert5, length5 * sizeof(wchar_t));
            error[i].insert5 = ptr;
            ptr += length5;
            *ptr++ = U_NULL;
        }

        if (insert6)
        {
            memmove(ptr, insert6, length6 * sizeof(wchar_t));
            error[i].insert6 = ptr;
            ptr += length6;
            *ptr++ = U_NULL;
        }

        if (insert7)
        {
            memmove(ptr, insert7, length7 * sizeof(wchar_t));
            error[i].insert7 = ptr;
            ptr += length7;
            *ptr++ = U_NULL;
        }

        if (insert8)
        {
            memmove(ptr, insert8, length8 * sizeof(wchar_t));
            error[i].insert8 = ptr;
            ptr += length8;
            *ptr++ = U_NULL;
        }

        if (insert9)
        {
            memmove(ptr, insert9, length9 * sizeof(wchar_t));
            error[i].insert9 = ptr;
            ptr += length9;
            *ptr++ = U_NULL;
        }
    }

    error[i].num         = i;
    error[i].left_token  = (left_token > right_token ? right_token : left_token);
    error[i].right_token = right_token;
    error[i].right_string_length = lex_stream -> NameLength(right_token);

    //
    // Dump the error immediately ?
    //
    if (control.option.dump_errors)
    {
        PrintEmacsMessage(i);

        if (buffer.Length() > 0)
        {
            delete [] buffer[0];
            buffer.Reset();
        }
        error.Reset(1); // we need at least 1 error in order for the return code to be set properly. See print_messages
        cout.flush();
    }
 
    return;
}

void SemanticError::StaticInitializer()
{
    memset(warning, 0, _num_kinds * sizeof(bool));

    warning[INVALID_OPTION] = 1;
    warning[CANNOT_OPEN_ZIP_FILE] = 1;

    warning[EMPTY_DECLARATION] = 1;
    warning[REDUNDANT_ABSTRACT] = 1;
    warning[REDUNDANT_FINAL] = 1;
    warning[REDUNDANT_PUBLIC] = 1;
    warning[REDUNDANT_STATIC] = 1;
    warning[OBSOLESCENT_ABSTRACT] = 1;
    warning[OBSOLESCENT_BRACKETS] = 1;
    warning[NO_TYPES] = 1;
    warning[PARENT_TYPE_IN_UNNAMED_PACKAGE] = 1;

    warning[MULTIPLE_PUBLIC_TYPES] = 1;
    warning[TYPE_IN_MULTIPLE_FILES] = 1;
    warning[MISMATCHED_TYPE_AND_FILE_NAMES] = 1;
    warning[REFERENCE_TO_TYPE_IN_MISMATCHED_FILE] = 1;
    warning[ONE_UNNAMED_PACKAGE] = 1;
    warning[RECOMPILATION] = 1;
    warning[METHOD_WITH_CONSTRUCTOR_NAME] = 1;

    warning[DEFAULT_METHOD_NOT_OVERRIDDEN] = 1;

    //
    // TODO: Review the cases below. They should be flagged as errors.
    //       However, since javac does not flag them at all, we only issue
    //       a warning.
    warning[INHERITANCE_AND_LEXICAL_SCOPING_CONFLICT_WITH_LOCAL] = 2;
    warning[INHERITANCE_AND_LEXICAL_SCOPING_CONFLICT_WITH_MEMBER] = 2;
    warning[PRIVATE_METHOD_OVERRIDE] = 1;
    warning[PRIVATE_METHOD_OVERRIDE_EXTERNALLY] = 1;

    //
    // Something stronger than a warning, but code will be generated anyway
    //
    warning[BAD_INPUT_FILE] = 2;
    warning[UNREADABLE_INPUT_FILE] = 2;

//
// TODO: Let these conditions be flagged as errors now.
//
//    warning[UNREACHABLE_CATCH_CLAUSE] = 2;
//    warning[VARIABLE_NOT_DEFINITELY_ASSIGNED] = 2;
//    warning[TARGET_VARIABLE_IS_FINAL] = 2;
//    warning[FINAL_VARIABLE_TARGET_IN_LOOP] = 2;
//    warning[VOID_TO_STRING] = 2;
//

#ifdef TEST
    for (int i = 0; i < _num_kinds; i++)
        print_message[i] = NULL;
#endif

    print_message[BAD_ERROR] = PrintBAD_ERROR;
    print_message[DEFAULT_ERROR] = PrintDEFAULT_ERROR;
    print_message[INVALID_OPTION] = PrintINVALID_OPTION;
    print_message[INVALID_K_OPTION] = PrintINVALID_K_OPTION;
    print_message[INVALID_K_TARGET] = PrintINVALID_K_TARGET;
    print_message[INVALID_TAB_VALUE] = PrintINVALID_TAB_VALUE;
    print_message[INVALID_DIRECTORY] = PrintINVALID_DIRECTORY;
    print_message[UNSUPPORTED_OPTION] = PrintUNSUPPORTED_OPTION;
    print_message[NO_CURRENT_DIRECTORY] = PrintNO_CURRENT_DIRECTORY;
    print_message[CANNOT_OPEN_ZIP_FILE] = PrintCANNOT_OPEN_ZIP_FILE;
    print_message[PACKAGE_NOT_FOUND] = PrintPACKAGE_NOT_FOUND;
    print_message[CANNOT_OPEN_DIRECTORY] = PrintCANNOT_OPEN_DIRECTORY;
    print_message[BAD_INPUT_FILE] = PrintBAD_INPUT_FILE;
    print_message[UNREADABLE_INPUT_FILE] = PrintUNREADABLE_INPUT_FILE;
    print_message[CANNOT_REOPEN_FILE] = PrintCANNOT_REOPEN_FILE;
    print_message[CANNOT_WRITE_FILE] = PrintCANNOT_WRITE_FILE;
    print_message[CANNOT_COMPUTE_COLUMNS] = PrintCANNOT_COMPUTE_COLUMNS;
    print_message[EMPTY_DECLARATION] = PrintEMPTY_DECLARATION;
    print_message[REDUNDANT_ABSTRACT] = PrintREDUNDANT_ABSTRACT;
    print_message[REDUNDANT_FINAL] = PrintREDUNDANT_FINAL;
    print_message[REDUNDANT_PUBLIC] = PrintREDUNDANT_PUBLIC;
    print_message[REDUNDANT_STATIC] = PrintREDUNDANT_STATIC;
    print_message[OBSOLESCENT_ABSTRACT] = PrintOBSOLESCENT_ABSTRACT;
    print_message[OBSOLESCENT_BRACKETS] = PrintOBSOLESCENT_BRACKETS;
    print_message[NO_TYPES] = PrintNO_TYPES;
    print_message[MULTIPLE_PUBLIC_TYPES] = PrintMULTIPLE_PUBLIC_TYPES;
    print_message[TYPE_IN_MULTIPLE_FILES] = PrintTYPE_IN_MULTIPLE_FILES;
    print_message[PACKAGE_TYPE_CONFLICT] = PrintPACKAGE_TYPE_CONFLICT;
    print_message[DIRECTORY_FILE_CONFLICT] = PrintDIRECTORY_FILE_CONFLICT;
    print_message[FILE_FILE_CONFLICT] = PrintFILE_FILE_CONFLICT;
    print_message[MISMATCHED_TYPE_AND_FILE_NAMES] = PrintMISMATCHED_TYPE_AND_FILE_NAMES;
    print_message[REFERENCE_TO_TYPE_IN_MISMATCHED_FILE] = PrintREFERENCE_TO_TYPE_IN_MISMATCHED_FILE;
    print_message[DUPLICATE_INNER_TYPE_NAME] = PrintDUPLICATE_INNER_TYPE_NAME;
    print_message[DUPLICATE_TYPE_DECLARATION] = PrintDUPLICATE_TYPE_DECLARATION;
    print_message[DUPLICATE_ACCESS_MODIFIER] = PrintDUPLICATE_ACCESS_MODIFIER;
    print_message[DUPLICATE_MODIFIER] = PrintDUPLICATE_MODIFIER;
    print_message[FINAL_ABSTRACT_CLASS] = PrintFINAL_ABSTRACT_CLASS;
    print_message[VOLATILE_FINAL] = PrintVOLATILE_FINAL;
    print_message[FINAL_VOLATILE] = PrintFINAL_VOLATILE;
    print_message[INVALID_TOP_LEVEL_CLASS_MODIFIER] = PrintINVALID_TOP_LEVEL_CLASS_MODIFIER;
    print_message[INVALID_INNER_CLASS_MODIFIER] = PrintINVALID_INNER_CLASS_MODIFIER;
    print_message[INVALID_STATIC_INNER_CLASS_MODIFIER] = PrintINVALID_STATIC_INNER_CLASS_MODIFIER;
    print_message[INVALID_LOCAL_CLASS_MODIFIER] = PrintINVALID_LOCAL_CLASS_MODIFIER;
    print_message[INVALID_INTERFACE_MODIFIER] = PrintINVALID_INTERFACE_MODIFIER;
    print_message[INVALID_FIELD_MODIFIER] = PrintINVALID_FIELD_MODIFIER;
    print_message[INVALID_LOCAL_MODIFIER] = PrintINVALID_LOCAL_MODIFIER;
    print_message[INVALID_METHOD_MODIFIER] = PrintINVALID_METHOD_MODIFIER;
    print_message[INVALID_SIGNATURE_MODIFIER] = PrintINVALID_SIGNATURE_MODIFIER;
    print_message[INVALID_CONSTRUCTOR_MODIFIER] = PrintINVALID_CONSTRUCTOR_MODIFIER;
    print_message[INVALID_CONSTANT_MODIFIER] = PrintINVALID_CONSTANT_MODIFIER;
    print_message[UNINITIALIZED_FIELD] = PrintUNINITIALIZED_FIELD;
    print_message[PARENT_TYPE_IN_UNNAMED_PACKAGE] = PrintPARENT_TYPE_IN_UNNAMED_PACKAGE;
    print_message[RECOMPILATION] = PrintRECOMPILATION;
    print_message[TYPE_NOT_FOUND] = PrintTYPE_NOT_FOUND;
    print_message[DUPLICATE_ON_DEMAND_IMPORT] = PrintDUPLICATE_ON_DEMAND_IMPORT;
    print_message[NOT_A_TYPE] = PrintNOT_A_TYPE;
    print_message[NOT_A_CLASS] = PrintNOT_A_CLASS;
    print_message[NOT_AN_INTERFACE] = PrintNOT_AN_INTERFACE;
    print_message[SUPER_IS_FINAL] = PrintSUPER_IS_FINAL;
    print_message[OBJECT_WITH_SUPER_TYPE] = PrintOBJECT_WITH_SUPER_TYPE;
    print_message[OBJECT_HAS_NO_SUPER_TYPE] = PrintOBJECT_HAS_NO_SUPER_TYPE;
    print_message[DUPLICATE_FIELD] = PrintDUPLICATE_FIELD;
    print_message[DUPLICATE_METHOD] = PrintDUPLICATE_METHOD;
    print_message[DUPLICATE_CONSTRUCTOR] = PrintDUPLICATE_CONSTRUCTOR;
    print_message[MISMATCHED_INHERITED_METHOD] = PrintMISMATCHED_INHERITED_METHOD;
    print_message[MISMATCHED_INHERITED_METHOD_EXTERNALLY] = PrintMISMATCHED_INHERITED_METHOD_EXTERNALLY;
    print_message[DUPLICATE_FORMAL_PARAMETER] = PrintDUPLICATE_FORMAL_PARAMETER;
    print_message[MISMATCHED_CONSTRUCTOR_NAME] = PrintMISMATCHED_CONSTRUCTOR_NAME;
    print_message[METHOD_WITH_CONSTRUCTOR_NAME] = PrintMETHOD_WITH_CONSTRUCTOR_NAME;
    print_message[DUPLICATE_LOCAL_VARIABLE_DECLARATION] = PrintDUPLICATE_LOCAL_VARIABLE_DECLARATION;
    print_message[DUPLICATE_LOCAL_TYPE_DECLARATION] = PrintDUPLICATE_LOCAL_TYPE_DECLARATION;
    print_message[MULTIPLE_DEFAULT_LABEL] = PrintMULTIPLE_DEFAULT_LABEL;
    print_message[UNDECLARED_LABEL] = PrintUNDECLARED_LABEL;
    print_message[DUPLICATE_LABEL] = PrintDUPLICATE_LABEL;
    print_message[CATCH_PRIMITIVE_TYPE] = PrintCATCH_PRIMITIVE_TYPE;
    print_message[CATCH_ARRAY_TYPE] = PrintCATCH_ARRAY_TYPE;
    print_message[AMBIGUOUS_NAME] = PrintAMBIGUOUS_NAME;
    print_message[FIELD_IS_TYPE] = PrintFIELD_IS_TYPE;
    print_message[FIELD_NOT_FOUND] = PrintFIELD_NOT_FOUND;
    print_message[FIELD_NAME_MISSPELLED] = PrintFIELD_NAME_MISSPELLED;
    print_message[FIELD_WITH_PRIVATE_ACCESS_NOT_ACCESSIBLE] = PrintFIELD_WITH_PRIVATE_ACCESS_NOT_ACCESSIBLE;
    print_message[FIELD_WITH_DEFAULT_ACCESS_NOT_ACCESSIBLE] = PrintFIELD_WITH_DEFAULT_ACCESS_NOT_ACCESSIBLE;
    print_message[NAME_NOT_FOUND] = PrintNAME_NOT_FOUND;
    print_message[METHOD_NOT_FIELD] = PrintMETHOD_NOT_FIELD;
    print_message[NAME_NOT_YET_AVAILABLE] = PrintNAME_NOT_YET_AVAILABLE;
    print_message[NAME_NOT_VARIABLE] = PrintNAME_NOT_VARIABLE;
    print_message[NAME_NOT_CLASS_VARIABLE] = PrintNAME_NOT_CLASS_VARIABLE;
    print_message[NOT_A_NUMERIC_VARIABLE] = PrintNOT_A_NUMERIC_VARIABLE;
    print_message[METHOD_NOT_FOUND] = PrintMETHOD_NOT_FOUND;
    print_message[METHOD_NAME_NOT_FOUND_IN_TYPE] = PrintMETHOD_NAME_NOT_FOUND_IN_TYPE;
    print_message[METHOD_NAME_MISSPELLED] = PrintMETHOD_NAME_MISSPELLED;
    print_message[METHOD_WITH_PRIVATE_ACCESS_NOT_ACCESSIBLE] = PrintMETHOD_WITH_PRIVATE_ACCESS_NOT_ACCESSIBLE;
    print_message[METHOD_WITH_DEFAULT_ACCESS_NOT_ACCESSIBLE] = PrintMETHOD_WITH_DEFAULT_ACCESS_NOT_ACCESSIBLE;
    print_message[HIDDEN_METHOD_IN_ENCLOSING_CLASS] = PrintHIDDEN_METHOD_IN_ENCLOSING_CLASS;
    print_message[FIELD_NOT_METHOD] = PrintFIELD_NOT_METHOD;
    print_message[TYPE_NOT_METHOD] = PrintTYPE_NOT_METHOD;
    print_message[TYPE_NOT_FIELD] = PrintTYPE_NOT_FIELD;
    print_message[METHOD_NOT_CLASS_METHOD] = PrintMETHOD_NOT_CLASS_METHOD;
    print_message[AMBIGUOUS_CONSTRUCTOR_INVOCATION] = PrintAMBIGUOUS_CONSTRUCTOR_INVOCATION;
    print_message[AMBIGUOUS_METHOD_INVOCATION] = PrintAMBIGUOUS_METHOD_INVOCATION;
    print_message[CONSTRUCTOR_NOT_FOUND] = PrintCONSTRUCTOR_NOT_FOUND;
    print_message[METHOD_FOUND_FOR_CONSTRUCTOR] = PrintMETHOD_FOUND_FOR_CONSTRUCTOR;
    print_message[ABSTRACT_TYPE_CREATION] = PrintABSTRACT_TYPE_CREATION;
    print_message[INVALID_INSTANCEOF_CONVERSION] = PrintINVALID_INSTANCEOF_CONVERSION;
    print_message[INVALID_CAST_CONVERSION] = PrintINVALID_CAST_CONVERSION;
    print_message[INVALID_CAST_TYPE] = PrintINVALID_CAST_TYPE;
    print_message[INCOMPATIBLE_TYPE_FOR_INITIALIZATION] = PrintINCOMPATIBLE_TYPE_FOR_INITIALIZATION;
    print_message[INCOMPATIBLE_TYPE_FOR_ASSIGNMENT] = PrintINCOMPATIBLE_TYPE_FOR_ASSIGNMENT;
    print_message[INCOMPATIBLE_TYPE_FOR_BINARY_EXPRESSION] = PrintINCOMPATIBLE_TYPE_FOR_BINARY_EXPRESSION;
    print_message[INCOMPATIBLE_TYPE_FOR_CONDITIONAL_EXPRESSION] = PrintINCOMPATIBLE_TYPE_FOR_CONDITIONAL_EXPRESSION;
    print_message[VOID_ARRAY] = PrintVOID_ARRAY;
    print_message[VOID_TYPE_IN_EQUALITY_EXPRESSION] = PrintVOID_TYPE_IN_EQUALITY_EXPRESSION;
    print_message[TYPE_NOT_THROWABLE] = PrintTYPE_NOT_THROWABLE;
    print_message[TYPE_NOT_PRIMITIVE] = PrintTYPE_NOT_PRIMITIVE;
    print_message[TYPE_NOT_INTEGRAL] = PrintTYPE_NOT_INTEGRAL;
    print_message[TYPE_NOT_NUMERIC] = PrintTYPE_NOT_NUMERIC;
    print_message[TYPE_NOT_INTEGER] = PrintTYPE_NOT_INTEGER;
    print_message[TYPE_NOT_BOOLEAN] = PrintTYPE_NOT_BOOLEAN;
    print_message[TYPE_NOT_ARRAY] = PrintTYPE_NOT_ARRAY;
    print_message[TYPE_NOT_REFERENCE] = PrintTYPE_NOT_REFERENCE;
    print_message[TYPE_NOT_VALID_FOR_SWITCH] = PrintTYPE_NOT_VALID_FOR_SWITCH;
    print_message[TYPE_IS_VOID] = PrintTYPE_IS_VOID;
    print_message[VALUE_NOT_REPRESENTABLE_IN_TYPE] = PrintVALUE_NOT_REPRESENTABLE_IN_TYPE;
    print_message[DUPLICATE_CASE_VALUE] = PrintDUPLICATE_CASE_VALUE;
    print_message[MISPLACED_THIS_EXPRESSION] = PrintMISPLACED_THIS_EXPRESSION;
    print_message[MISPLACED_SUPER_EXPRESSION] = PrintMISPLACED_SUPER_EXPRESSION;
    print_message[TARGET_VARIABLE_IS_FINAL] = PrintTARGET_VARIABLE_IS_FINAL;
    print_message[FINAL_VARIABLE_TARGET_IN_LOOP] = PrintFINAL_VARIABLE_TARGET_IN_LOOP;
    print_message[UNINITIALIZED_FINAL_VARIABLE] = PrintUNINITIALIZED_FINAL_VARIABLE;
    print_message[UNINITIALIZED_STATIC_FINAL_VARIABLE] = PrintUNINITIALIZED_STATIC_FINAL_VARIABLE;
    print_message[UNINITIALIZED_FINAL_VARIABLE_IN_CONSTRUCTOR] = PrintUNINITIALIZED_FINAL_VARIABLE_IN_CONSTRUCTOR;
    print_message[INIT_SCALAR_WITH_ARRAY] = PrintINIT_SCALAR_WITH_ARRAY;
    print_message[INIT_ARRAY_WITH_SCALAR] = PrintINIT_ARRAY_WITH_SCALAR;
    print_message[INVALID_BYTE_VALUE] = PrintINVALID_BYTE_VALUE;
    print_message[INVALID_SHORT_VALUE] = PrintINVALID_SHORT_VALUE;
    print_message[INVALID_CHARACTER_VALUE] = PrintINVALID_CHARACTER_VALUE;
    print_message[INVALID_INT_VALUE] = PrintINVALID_INT_VALUE;
    print_message[INVALID_LONG_VALUE] = PrintINVALID_LONG_VALUE;
    print_message[INVALID_FLOAT_VALUE] = PrintINVALID_FLOAT_VALUE;
    print_message[INVALID_DOUBLE_VALUE] = PrintINVALID_DOUBLE_VALUE;
    print_message[INVALID_STRING_VALUE] = PrintINVALID_STRING_VALUE;
    print_message[RETURN_STATEMENT_IN_INITIALIZER] = PrintRETURN_STATEMENT_IN_INITIALIZER;
    print_message[MISPLACED_RETURN_WITH_EXPRESSION] = PrintMISPLACED_RETURN_WITH_EXPRESSION;
    print_message[MISPLACED_RETURN_WITH_NO_EXPRESSION] = PrintMISPLACED_RETURN_WITH_NO_EXPRESSION;
    print_message[MISMATCHED_RETURN_AND_METHOD_TYPE] = PrintMISMATCHED_RETURN_AND_METHOD_TYPE;
    print_message[EXPRESSION_NOT_THROWABLE] = PrintEXPRESSION_NOT_THROWABLE;
    print_message[BAD_THROWABLE_EXPRESSION_IN_TRY] = PrintBAD_THROWABLE_EXPRESSION_IN_TRY;
    print_message[BAD_THROWABLE_EXPRESSION_IN_METHOD] = PrintBAD_THROWABLE_EXPRESSION_IN_METHOD;
    print_message[BAD_THROWABLE_EXPRESSION] = PrintBAD_THROWABLE_EXPRESSION;
    print_message[MISPLACED_BREAK_STATEMENT] = PrintMISPLACED_BREAK_STATEMENT;
    print_message[MISPLACED_CONTINUE_STATEMENT] = PrintMISPLACED_CONTINUE_STATEMENT;
    print_message[MISPLACED_EXPLICIT_CONSTRUCTOR_INVOCATION] = PrintMISPLACED_EXPLICIT_CONSTRUCTOR_INVOCATION;
    print_message[INVALID_CONTINUE_TARGET] = PrintINVALID_CONTINUE_TARGET;
    print_message[NON_ABSTRACT_TYPE_CONTAINS_ABSTRACT_METHOD] = PrintNON_ABSTRACT_TYPE_CONTAINS_ABSTRACT_METHOD;
    print_message[NON_ABSTRACT_TYPE_INHERITS_ABSTRACT_METHOD] = PrintNON_ABSTRACT_TYPE_INHERITS_ABSTRACT_METHOD;
    print_message[NON_ABSTRACT_TYPE_INHERITS_ABSTRACT_METHOD_FROM_ABSTRACT_CLASS] = PrintNON_ABSTRACT_TYPE_INHERITS_ABSTRACT_METHOD_FROM_ABSTRACT_CLASS;
    print_message[NON_ABSTRACT_TYPE_CANNOT_OVERRIDE_DEFAULT_ABSTRACT_METHOD] = PrintNON_ABSTRACT_TYPE_CANNOT_OVERRIDE_DEFAULT_ABSTRACT_METHOD;
    print_message[NO_ABSTRACT_METHOD_IMPLEMENTATION] = PrintNO_ABSTRACT_METHOD_IMPLEMENTATION;
    print_message[DUPLICATE_INTERFACE] = PrintDUPLICATE_INTERFACE;
    print_message[UNKNOWN_QUALIFIED_NAME_BASE] = PrintUNKNOWN_QUALIFIED_NAME_BASE;
    print_message[UNKNOWN_AMBIGUOUS_NAME] = PrintUNKNOWN_AMBIGUOUS_NAME;
    print_message[CIRCULAR_INTERFACE] = PrintCIRCULAR_INTERFACE;
    print_message[CIRCULAR_CLASS] = PrintCIRCULAR_CLASS;
    print_message[TYPE_NOT_ACCESSIBLE] = PrintTYPE_NOT_ACCESSIBLE;
    print_message[PRIVATE_FIELD_NOT_ACCESSIBLE] = PrintPRIVATE_FIELD_NOT_ACCESSIBLE;
    print_message[PROTECTED_FIELD_NOT_ACCESSIBLE] = PrintPROTECTED_FIELD_NOT_ACCESSIBLE;
    print_message[DEFAULT_FIELD_NOT_ACCESSIBLE] = PrintDEFAULT_FIELD_NOT_ACCESSIBLE;
    print_message[PRIVATE_METHOD_NOT_ACCESSIBLE] = PrintPRIVATE_METHOD_NOT_ACCESSIBLE;
    print_message[PROTECTED_METHOD_NOT_ACCESSIBLE] = PrintPROTECTED_METHOD_NOT_ACCESSIBLE;
    print_message[DEFAULT_METHOD_NOT_ACCESSIBLE] = PrintDEFAULT_METHOD_NOT_ACCESSIBLE;
    print_message[PRIVATE_CONSTRUCTOR_NOT_ACCESSIBLE] = PrintPRIVATE_CONSTRUCTOR_NOT_ACCESSIBLE;
    print_message[PROTECTED_CONSTRUCTOR_NOT_ACCESSIBLE] = PrintPROTECTED_CONSTRUCTOR_NOT_ACCESSIBLE;
    print_message[DEFAULT_CONSTRUCTOR_NOT_ACCESSIBLE] = PrintDEFAULT_CONSTRUCTOR_NOT_ACCESSIBLE;
    print_message[CONSTRUCTOR_DOES_NOT_THROW_THIS_EXCEPTION] = PrintCONSTRUCTOR_DOES_NOT_THROW_THIS_EXCEPTION;
    print_message[CONSTRUCTOR_DOES_NOT_THROW_SUPER_EXCEPTION] = PrintCONSTRUCTOR_DOES_NOT_THROW_SUPER_EXCEPTION;
    print_message[PARAMETER_REDECLARED] = PrintPARAMETER_REDECLARED;
    print_message[BAD_ABSTRACT_METHOD_MODIFIER] = PrintBAD_ABSTRACT_METHOD_MODIFIER;
    print_message[ABSTRACT_METHOD_MODIFIER_CONFLICT] = PrintABSTRACT_METHOD_MODIFIER_CONFLICT;
    print_message[ABSTRACT_METHOD_INVOCATION] = PrintABSTRACT_METHOD_INVOCATION;
    print_message[FINAL_METHOD_OVERRIDE] = PrintFINAL_METHOD_OVERRIDE;
    print_message[FINAL_METHOD_OVERRIDE_EXTERNALLY] = PrintFINAL_METHOD_OVERRIDE_EXTERNALLY;
    print_message[PRIVATE_METHOD_OVERRIDE] = PrintPRIVATE_METHOD_OVERRIDE;
    print_message[PRIVATE_METHOD_OVERRIDE_EXTERNALLY] = PrintPRIVATE_METHOD_OVERRIDE_EXTERNALLY;
    print_message[INSTANCE_METHOD_OVERRIDE] = PrintINSTANCE_METHOD_OVERRIDE;
    print_message[INSTANCE_METHOD_OVERRIDE_EXTERNALLY] = PrintINSTANCE_METHOD_OVERRIDE_EXTERNALLY;
    print_message[CLASS_METHOD_OVERRIDE] = PrintCLASS_METHOD_OVERRIDE;
    print_message[CLASS_METHOD_OVERRIDE_EXTERNALLY] = PrintCLASS_METHOD_OVERRIDE_EXTERNALLY;
    print_message[MISMATCHED_OVERRIDDEN_EXCEPTION] = PrintMISMATCHED_OVERRIDDEN_EXCEPTION;
    print_message[MISMATCHED_OVERRIDDEN_EXCEPTION_EXTERNALLY] = PrintMISMATCHED_OVERRIDDEN_EXCEPTION_EXTERNALLY;
    print_message[ABSTRACT_METHOD_WITH_BODY] = PrintABSTRACT_METHOD_WITH_BODY;
    print_message[NON_ABSTRACT_METHOD_WITHOUT_BODY] = PrintNON_ABSTRACT_METHOD_WITHOUT_BODY;
    print_message[BAD_ACCESS_METHOD_OVERRIDE] = PrintBAD_ACCESS_METHOD_OVERRIDE;
    print_message[BAD_ACCESS_METHOD_OVERRIDE_EXTERNALLY] = PrintBAD_ACCESS_METHOD_OVERRIDE_EXTERNALLY;
    print_message[STATIC_OVERRIDE_ABSTRACT] = PrintSTATIC_OVERRIDE_ABSTRACT;
    print_message[STATIC_OVERRIDE_ABSTRACT_EXTERNALLY] = PrintSTATIC_OVERRIDE_ABSTRACT_EXTERNALLY;
    print_message[CIRCULAR_THIS_CALL] = PrintCIRCULAR_THIS_CALL;
    print_message[INSTANCE_VARIABLE_IN_EXPLICIT_CONSTRUCTOR_INVOCATION] = PrintINSTANCE_VARIABLE_IN_EXPLICIT_CONSTRUCTOR_INVOCATION;
    print_message[INSTANCE_METHOD_IN_EXPLICIT_CONSTRUCTOR_INVOCATION] = PrintINSTANCE_METHOD_IN_EXPLICIT_CONSTRUCTOR_INVOCATION;
    print_message[SYNTHETIC_VARIABLE_ACCESS] = PrintSYNTHETIC_VARIABLE_ACCESS;
    print_message[SYNTHETIC_METHOD_INVOCATION] = PrintSYNTHETIC_METHOD_INVOCATION;
    print_message[THIS_IN_EXPLICIT_CONSTRUCTOR_INVOCATION] = PrintTHIS_IN_EXPLICIT_CONSTRUCTOR_INVOCATION;
    print_message[SUPER_IN_EXPLICIT_CONSTRUCTOR_INVOCATION] = PrintSUPER_IN_EXPLICIT_CONSTRUCTOR_INVOCATION;
    print_message[EXPRESSION_NOT_CONSTANT] = PrintEXPRESSION_NOT_CONSTANT;
    print_message[UNCATCHABLE_METHOD_THROWN_CHECKED_EXCEPTION] = PrintUNCATCHABLE_METHOD_THROWN_CHECKED_EXCEPTION;
    print_message[UNCATCHABLE_CONSTRUCTOR_THROWN_CHECKED_EXCEPTION] = PrintUNCATCHABLE_CONSTRUCTOR_THROWN_CHECKED_EXCEPTION;
    print_message[UNREACHABLE_CATCH_CLAUSE] = PrintUNREACHABLE_CATCH_CLAUSE;
    print_message[UNREACHABLE_STATEMENT] = PrintUNREACHABLE_STATEMENT;
    print_message[UNREACHABLE_STATEMENTS] = PrintUNREACHABLE_STATEMENTS;
    print_message[UNREACHABLE_CONSTRUCTOR_BODY] = PrintUNREACHABLE_CONSTRUCTOR_BODY;
    print_message[BLOCKED_CATCH_CLAUSE] = PrintBLOCKED_CATCH_CLAUSE;
    print_message[VARIABLE_NOT_DEFINITELY_ASSIGNED] = PrintVARIABLE_NOT_DEFINITELY_ASSIGNED;
    print_message[TYPED_METHOD_WITH_NO_RETURN] = PrintTYPED_METHOD_WITH_NO_RETURN;

    print_message[DEFAULT_METHOD_NOT_OVERRIDDEN] = PrintDEFAULT_METHOD_NOT_OVERRIDDEN;

    print_message[ONE_UNNAMED_PACKAGE] = PrintONE_UNNAMED_PACKAGE;
    print_message[TYPE_NOT_IN_UNNAMED_PACKAGE] = PrintTYPE_NOT_IN_UNNAMED_PACKAGE;
    print_message[TYPE_IN_WRONG_PACKAGE] = PrintTYPE_IN_WRONG_PACKAGE;
    print_message[TYPE_NAME_MISMATCH] = PrintTYPE_NAME_MISMATCH;

    print_message[COMPRESSED_ZIP_FILE] = PrintCOMPRESSED_ZIP_FILE;
    print_message[INVALID_CLASS_FILE] = PrintINVALID_CLASS_FILE;
    print_message[CANNOT_OPEN_CLASS_FILE] = PrintCANNOT_OPEN_CLASS_FILE;

    print_message[ONE_ONE_FEATURE] = PrintONE_ONE_FEATURE;
    print_message[STATIC_NOT_INNER_CLASS] = PrintSTATIC_NOT_INNER_CLASS;
    print_message[TYPE_NOT_INNER_CLASS] = PrintTYPE_NOT_INNER_CLASS;
    print_message[SUPER_TYPE_NOT_INNER_CLASS] = PrintSUPER_TYPE_NOT_INNER_CLASS;
    print_message[STATIC_FIELD_IN_INNER_CLASS] = PrintSTATIC_FIELD_IN_INNER_CLASS;
    print_message[STATIC_METHOD_IN_INNER_CLASS] = PrintSTATIC_METHOD_IN_INNER_CLASS;
    print_message[STATIC_TYPE_IN_INNER_CLASS] = PrintSTATIC_TYPE_IN_INNER_CLASS;
    print_message[STATIC_INITIALIZER_IN_INNER_CLASS] = PrintSTATIC_INITIALIZER_IN_INNER_CLASS;
    print_message[INNER_CLASS_REFERENCE_TO_NON_FINAL_LOCAL_VARIABLE] = PrintINNER_CLASS_REFERENCE_TO_NON_FINAL_LOCAL_VARIABLE;
    print_message[INHERITANCE_AND_LEXICAL_SCOPING_CONFLICT_WITH_LOCAL] = PrintINHERITANCE_AND_LEXICAL_SCOPING_CONFLICT_WITH_LOCAL;
    print_message[INHERITANCE_AND_LEXICAL_SCOPING_CONFLICT_WITH_MEMBER] = PrintINHERITANCE_AND_LEXICAL_SCOPING_CONFLICT_WITH_MEMBER;
    print_message[ILLEGAL_THIS_FIELD_ACCESS] = PrintILLEGAL_THIS_FIELD_ACCESS;
    print_message[CONSTRUCTOR_FOUND_IN_ANONYMOUS_CLASS] = PrintCONSTRUCTOR_FOUND_IN_ANONYMOUS_CLASS;
    print_message[ENCLOSING_INSTANCE_NOT_ACCESSIBLE] = PrintENCLOSING_INSTANCE_NOT_ACCESSIBLE;
    print_message[INVALID_ENCLOSING_INSTANCE] = PrintINVALID_ENCLOSING_INSTANCE;
    print_message[PRIVATE_ENCLOSED_CONSTRUCTOR] = PrintPRIVATE_ENCLOSED_CONSTRUCTOR;
    print_message[ZERO_DIVIDE] = PrintZERO_DIVIDE;
    print_message[VOID_TO_STRING] = PrintVOID_TO_STRING;

#ifdef TEST
    for (int k = 0; k < _num_kinds; k++)
        assert(print_message[k] != NULL);
#endif
}


//
// This procedure uses a  quick sort algorithm to sort the ERRORS
// by the left_line_no and left_column_no fields.
//
void SemanticError::SortMessages()
{
     int lower,
         upper,
         lostack[32],
         histack[32];
 
     int top,
         i,
         j;
     ErrorInfo pivot,
               temp;

     top = 0;
     lostack[top] = 0;
     histack[top] = error.Length() - 1;
 
     while(top >= 0)
     {
         lower = lostack[top];
         upper = histack[top];
         top--;
 
         while(upper > lower)
         {
             //
             // The array is most-likely almost sorted. Therefore,
             // we use the middle element as the pivot element.
             //
             i = (lower + upper) / 2;
             pivot = error[i];
             error[i] = error[lower];
 
             //
             // Split the array section indicated by LOWER and UPPER
             // using ARRAY(LOWER) as the pivot.
             //
             i = lower;
             for (j = lower + 1; j <= upper; j++)
                 if ((error[j].left_token < pivot.left_token) ||
                 //
                 // When two error messages start in the same location
                 // and one is nested inside the other, the outer one
                 // is placed first so that it can be printed last.
                 // Recall that its right-span location is reached
                 // after the inner one has been completely processed.
                 //
                     (error[j].left_token == pivot.left_token &&
                      error[j].right_token > pivot.right_token) ||
                 //
                 // When two error messages are at the same location
                 // span, check the NUM field to keep the sort stable.
                 // When the location spans only a single symbol,
                 // the one with the lowest "num" is placed first.
                 //
                     (error[j].left_token  == pivot.left_token  &&
                      error[j].right_token == pivot.right_token &&
                      pivot.left_token == pivot.right_token     &&
                      error[j].num < pivot.num)                       ||
                 //
                 // When two error messages are at the same location
                 // which spans more than one symbol in the source,
                 // the first message is treated as being nested into
                 // the second message and (just like the nested case
                 // above) it is placed last in the sorted sequence.
                 //
                     (error[j].left_token  == pivot.left_token  &&
                      error[j].right_token == pivot.right_token &&
                      pivot.left_token < pivot.right_token      &&
                      error[j].num > pivot.num))
                 {
                     temp = error[++i];
                     error[i] = error[j];
                     error[j] = temp;
                 }
             error[lower] = error[i];
             error[i] = pivot;

             top++;
             if ((i - lower) < (upper - i))
             {
                 lostack[top] = i + 1;
                 histack[top] = upper;
                 upper = i - 1;
             }
             else
             {
                 histack[top] = i - 1;
                 lostack[top] = lower;
                 lower = i + 1;
             }
         }
     }

     return;
}


//
// This is the local private procedure that prints the semantic error messages.
//
int SemanticError::PrintMessages()
{
    int return_code = (num_errors > 0 ? 1 : 0);

    //
    // If the errors have not yet been dumped,...
    //
    if (! control.option.dump_errors)
    {
        if (control.option.errors)
        {
            if (num_errors == 0)
            {
                if (control.option.nowarn) // we only had warnings and they should not be reported
                    return return_code;

                cout << "\nIssued "
                     << num_warnings 
                     << (lex_stream -> file_symbol -> semantic == control.system_semantic ? " system" : " semantic")
                     << " warning" << (num_warnings <= 1 ? "" : "s");
            }
            else // we had some errors, and possibly warnings as well
            {
                cout << "\nFound "
                     << num_errors
                     << (lex_stream -> file_symbol -> semantic == control.system_semantic ? " system" : " semantic")
                     << " error" << (num_errors <= 1 ? "" : "s");
                if (num_warnings > 0 && !control.option.nowarn) 
                {
                     cout << " and issued "
                          << num_warnings << " warning" << (num_warnings <= 1 ? "" : "s");
                }
            }

            if (lex_stream -> file_symbol -> semantic != control.system_semantic)
            {
                cout << " compiling \"";
                Unicode::Cout(lex_stream -> FileName());
                cout << '\"';
            }
            cout << ':';

            //
            //
            //
            if (lex_stream -> file_symbol -> semantic != control.system_semantic)
            {
                lex_stream -> RereadInput();

                if (! lex_stream -> InputBuffer())
                {
                    char *file_name = lex_stream -> FileName();
                    int length = lex_stream -> FileNameLength();
                    wchar_t *name = new wchar_t[length + 1];
                    for (int i = 0; i < length; i++)
                        name[i] = file_name[i];
                    name[length] = U_NULL;
                    control.system_semantic -> ReportSemError(SemanticError::CANNOT_REOPEN_FILE,
                                                              0,
                                                              0,
                                                              name);
                    delete [] name;
                }
            }

            if (lex_stream -> file_symbol -> semantic == control.system_semantic || lex_stream -> InputBuffer())
            {
                SortMessages();
                for (int k = 0; k < error.Length(); k++)
                {
                    if ((warning[error[k].msg_code] != 1) || (! control.option.nowarn))
                    {
                        if (error[k].left_token < error[k].right_token)
                             PrintLargeSource(k);
                        else PrintSmallSource(k);
                        cout << "\n*** " << (warning[error[k].msg_code] == 1
                                                    ? "Warning: "
                                                    : (warning[error[k].msg_code] == 2 && (! control.option.zero_defect)
                                                              ? "Caution: "
                                                              : "Error: "));
                        (print_message[error[k].msg_code]) (error[k], lex_stream, control);
                        cout << '\n';
                    }
                }
                lex_stream -> DestroyInput();
            }
        }
        else
        {
            if (lex_stream -> file_symbol -> semantic != control.system_semantic)
            {
                if (! lex_stream -> ComputeColumns())
                {
                    char *file_name = lex_stream -> FileName();
                    int length = lex_stream -> FileNameLength();
                    wchar_t *name = new wchar_t[length + 1];
                    for (int i = 0; i < length; i++)
                        name[i] = file_name[i];
                    name[length] = U_NULL;
                    control.system_semantic -> ReportSemError(SemanticError::CANNOT_COMPUTE_COLUMNS,
                                                              0,
                                                              0,
                                                              name);
                    delete [] name;
                }
            }

            SortMessages();
            for (int k = 0; k < error.Length(); k++)
            {
                if ((warning[error[k].msg_code] != 1) || (! control.option.nowarn))
                    PrintEmacsMessage(k);
            }
        }
    }

    cout.flush();
    cerr.flush();

    return return_code;
}


void SemanticError::PrintEmacsMessage(int k)
{
    int left_line_no    = lex_stream -> Line(error[k].left_token),
        left_column_no  = lex_stream -> Column(error[k].left_token),
        right_line_no   = lex_stream -> Line(error[k].right_token),
        right_column_no = lex_stream -> Column(error[k].right_token);

    if (right_column_no != 0) // could not compute a column number
        right_column_no += (error[k].right_string_length - 1); // point to last character in right token

    Unicode::Cout(lex_stream -> FileName());
    cout << ':' << left_line_no  << ':' << left_column_no 
         << ':' << right_line_no << ':' << right_column_no
         << (warning[error[k].msg_code] == 1
                    ? ":\n    Warning: "
                    : (warning[error[k].msg_code] == 2  && (! control.option.zero_defect)
                              ? ":\n    Caution: "
                              : ":\n    Error: "));
    (print_message[error[k].msg_code]) (error[k], lex_stream, control);
    cout << '\n';

    return;
}


//
// This procedure is invoked to print a large message that may
// span more than one line. The parameter message points to the
// starting line. The parameter k points to the error message in
// the error structure.
//
void SemanticError::PrintLargeSource(int k)
{
    int left_line_no    = lex_stream -> Line(error[k].left_token),
        left_column_no  = lex_stream -> Column(error[k].left_token),
        right_line_no   = lex_stream -> Line(error[k].right_token),
        right_column_no = lex_stream -> Column(error[k].right_token);
 
    if (left_line_no == right_line_no)
    {
        if (left_line_no == 0)
            cout << "\n";
        else
        {
            cout << "\n\n";
            cout.width(6);
            cout << left_line_no << ". ";
            for (int i = lex_stream -> LineStart(left_line_no); i <= lex_stream -> LineEnd(left_line_no); i++)
                Unicode::Cout(lex_stream -> InputBuffer()[i]);

            cout.width(left_column_no + 8);
            cout << "<";
            cout.width(right_column_no + error[k].right_string_length - left_column_no - 1);
            cout.fill('-');
            cout << ">";
            cout.fill(' ');
        }
    }
    else
    {
        cout << "\n\n";
        cout.width(left_column_no + 8);
        cout << "<";

        cout.width(lex_stream -> LineSegmentLength(error[k].left_token));
        cout.fill('-');
        cout << "\n";
        cout.fill(' ');

        cout.width(6);
        cout << left_line_no << ". ";
        for (int i = lex_stream -> LineStart(left_line_no); i <= lex_stream -> LineEnd(left_line_no); i++)
            Unicode::Cout(lex_stream -> InputBuffer()[i]);

        if (right_line_no > left_line_no + 1)
        {
            cout.width(left_column_no + 7);
            cout << " ";
            cout << ". . .\n";
        }

        cout.width(6);
        cout << right_line_no << ". ";
        for (int j = lex_stream -> LineStart(right_line_no); j <= lex_stream -> LineEnd(right_line_no); j++)
            Unicode::Cout(lex_stream -> InputBuffer()[j]);

        cout.width(8);
        cout << "";
        cout.width(right_column_no + error[k].right_string_length - 1);
        cout.fill('-');
        cout << ">";
        cout.fill(' ');
    }
 
    return;
}
 
//
// This procedure is invoked to print a small message that may
// only span a single line. The parameter k points to the error
// message in the error structure.
//
void SemanticError::PrintSmallSource(int k)
{
    int left_line_no = lex_stream -> Line(error[k].left_token);

    if (left_line_no == 0)
        cout << "\n";
    else
    {
        cout << "\n\n";
        cout.width(6);
        cout << left_line_no;
        cout << ". ";

        for (int i = lex_stream -> LineStart(left_line_no); i <= lex_stream -> LineEnd(left_line_no); i++)
            Unicode::Cout(lex_stream -> InputBuffer()[i]);

        int left_column_no = lex_stream -> Column(error[k].left_token),
            right_column_no = lex_stream -> Column(error[k].right_token);

        cout.width(left_column_no + 7);
        cout << "";
        if (left_column_no == right_column_no && error[k].right_string_length == 1)
            cout << '^';
        else
        {
            cout << '<';
            cout.width(right_column_no + error[k].right_string_length - left_column_no - 1);
            cout.fill('-');
            cout << ">";
            cout.fill(' ');
        }
    }
 
    return;
}


//
// These "print_" procedures are invoked to print specific
// error messages. The parameter err identifies the error to
// be processed.
//
void SemanticError::PrintBAD_ERROR(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cerr << "chaos: Error code " << err.msg_code << " is not a valid error message code\n";

    return;
}


void SemanticError::PrintDEFAULT_ERROR(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    if (err.insert1)
        Unicode::Cout(err.insert1);
    if (err.insert2)
        Unicode::Cout(err.insert2);
    if (err.insert3)
        Unicode::Cout(err.insert3);
    if (err.insert4)
        Unicode::Cout(err.insert4);
    if (err.insert5)
        Unicode::Cout(err.insert5);
    if (err.insert6)
        Unicode::Cout(err.insert6);
    if (err.insert7)
        Unicode::Cout(err.insert7);
    if (err.insert8)
        Unicode::Cout(err.insert8);
    if (err.insert9)
        Unicode::Cout(err.insert9);

    return;
}


void SemanticError::PrintINVALID_OPTION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << '\"';
    Unicode::Cout(err.insert1);
    cout << "\" is an invalid option; "
         << StringConstant::U8S_command_format;

    return;
}


void SemanticError::PrintINVALID_K_OPTION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "No argument specified for +K option. The proper form is \"+Kxxx=xxx\" (with no intervening space)";

    return;
}


void SemanticError::PrintINVALID_K_TARGET(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << '\"';
    Unicode::Cout(err.insert1);
    cout << "\" is not a valid target in a +K option. The target must be a numeric type or boolean";

    return;
}


void SemanticError::PrintINVALID_TAB_VALUE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << '\"';
    Unicode::Cout(err.insert1);
    cout << "\" is not a valid tab size. An integer value is expected";

    return;
}


void SemanticError::PrintINVALID_DIRECTORY(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The directory specified in the \"-d\" option, \"";
    Unicode::Cout(err.insert1);
    cout << "\", is either invalid or it could not be expanded";

    return;
}


void SemanticError::PrintUNSUPPORTED_OPTION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "This option \"";
    Unicode::Cout(err.insert1);
    cout << "\" is currently unsupported";

    return;
}


void SemanticError::PrintNO_CURRENT_DIRECTORY(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Could not open current directory";
    return;
}


void SemanticError::PrintCANNOT_OPEN_ZIP_FILE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "\"";
    Unicode::Cout(err.insert1);
    cout << "\" is either not a valid zip file or it contains a zip file comment. "
            "If it contains a comment, rezip it without the comment...";

    return;
}


void SemanticError::PrintPACKAGE_NOT_FOUND(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Could not find package named: \n";
    for (int i = 1; i < control.classpath.Length(); i++)
    {
        PathSymbol *path_symbol = control.classpath[i];
        wchar_t *path = path_symbol -> Name();

        cout << "                ";
        Unicode::Cout(path);
        if (path_symbol -> IsZip())
        {
            cout << "(";
            Unicode::Cout(err.insert1);
            cout << ")";
        }
        else
        {
            cout << "/";
            Unicode::Cout(err.insert1);
        }

        if (i + 2 < control.classpath.Length())
             cout << ", \n";
        else if (i + 2 == control.classpath.Length())
             cout << " or \n";
    }

    return;
}


void SemanticError::PrintCANNOT_OPEN_DIRECTORY(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Unable to open directory \"";
    Unicode::Cout(err.insert1);
    cout << "\"";

    return;
}


void SemanticError::PrintBAD_INPUT_FILE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The input file \"";
    Unicode::Cout(err.insert1);
    cout << "\" does not have the \".java\" extension";

    return;
}


void SemanticError::PrintUNREADABLE_INPUT_FILE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The input file \"";
    Unicode::Cout(err.insert1);
    cout << "\" was not found";

    return;
}


void SemanticError::PrintCANNOT_REOPEN_FILE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Unable to reopen file \"";
    Unicode::Cout(err.insert1);
    cout << "\"";

    return;
}


void SemanticError::PrintCANNOT_WRITE_FILE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Unable to write file \"";
    Unicode::Cout(err.insert1);
    cout << "\"";

    return;
}


void SemanticError::PrintCANNOT_COMPUTE_COLUMNS(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Unable to reopen file \"";
    Unicode::Cout(err.insert1);
    cout << "\". Therefore, column positions may be incorrect";

    return;
}


void SemanticError::PrintREDUNDANT_ABSTRACT(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The use of the \"abstract\" modifier in this context is redundant and strongly discouraged as a matter of style";

    return;
}


void SemanticError::PrintREDUNDANT_FINAL(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The use of the \"final\" modifier in this context is redundant and strongly discouraged as a matter of style";

    return;
}


void SemanticError::PrintREDUNDANT_PUBLIC(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The use of the \"public\" modifier in this context is redundant and strongly discouraged as a matter of style";

    return;
}


void SemanticError::PrintREDUNDANT_STATIC(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The use of the \"static\" modifier in this context is redundant and strongly discouraged as a matter of style";

    return;
}


void SemanticError::PrintEMPTY_DECLARATION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "An EmptyDeclaration is a deprecated feature that should not be used - \";\" ignored";

    return;
}


void SemanticError::PrintOBSOLESCENT_ABSTRACT(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Every interface in implicitly abstract. This modifier is obsolete and should not be used in new Java programs";

    return;
}


void SemanticError::PrintOBSOLESCENT_BRACKETS(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The use of empty bracket pairs following a MethodDeclarator should not be used in new Java programs";

    return;
}


void SemanticError::PrintNO_TYPES(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "This compilation unit contains no type declaration";

    return;
}


void SemanticError::PrintTYPE_IN_MULTIPLE_FILES(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The file \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    cout << ".java\" contains type \"";
    Unicode::Cout(err.insert4);
    cout << "\" which conflicts with file \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << "/";
    }
    Unicode::Cout(err.insert4);
    cout << ".java\"";

    return;
}


void SemanticError::PrintPACKAGE_TYPE_CONFLICT(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    cout << "\" contained in file \"";
    Unicode::Cout(err.insert3);
    cout << "\" conflicts with the package \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    cout << "\"";

    return;
}


void SemanticError::PrintDIRECTORY_FILE_CONFLICT(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type \"";
    Unicode::Cout(err.insert1);
    cout << "\" contained in file \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << "/";
    }
    Unicode::Cout(err.insert3);
    cout << ".java\" conflicts with the directory \"";
    Unicode::Cout(err.insert4);
    cout << "\"";

    return;
}


void SemanticError::PrintFILE_FILE_CONFLICT(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Cannot write class file \"";
    Unicode::Cout(err.insert1);
    cout << ".class\" because that name conflicts with the name of the class file \"";
    Unicode::Cout(err.insert2);
    cout << "\" in directory \"";
    Unicode::Cout(err.insert3);
    cout << "\". This is illegal because file names are case-insensitive in this system";

    return;
}


void SemanticError::PrintMULTIPLE_PUBLIC_TYPES(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type \"";
    Unicode::Cout(err.insert1);
    cout << "\" is declared public in compilation unit \"";
    Unicode::Cout(lex_stream -> FileName());
    cout<< "\" which also contains the public type, \"";
    Unicode::Cout(err.insert2);
    cout << "\"";

    return;
}


void SemanticError::PrintMISMATCHED_TYPE_AND_FILE_NAMES(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The public type \"";
    Unicode::Cout(err.insert1);
    cout << "\" does not match the name of its containing file \"";
    Unicode::Cout(lex_stream -> FileName());
    cout << "\"";

    return;
}


void SemanticError::PrintREFERENCE_TO_TYPE_IN_MISMATCHED_FILE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type \"";
    Unicode::Cout(err.insert1);
    cout << "\" is defined in the file \"";
    Unicode::Cout(err.insert2);
    cout << ".java\" but referenced in the file \"";
    Unicode::Cout(lex_stream -> FileName());
    cout << "\". It is recommended that it be redefined in \"";
    Unicode::Cout(err.insert1);
    cout << ".java\"";

    return;
}


void SemanticError::PrintDUPLICATE_INNER_TYPE_NAME(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The inner type named \"";
    Unicode::Cout(err.insert1);
    cout << "\" is nested in an outer class of the same name at location ";
    Unicode::Cout(err.insert2);

    return;
}


void SemanticError::PrintDUPLICATE_TYPE_DECLARATION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Duplicate declaration of type \"";
    Unicode::Cout(err.insert1);
    cout << "\". The other occurrence is at location ";
    Unicode::Cout(err.insert2);

    return;
}


void SemanticError::PrintUNINITIALIZED_FIELD(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The field \"";
    Unicode::Cout(err.insert1);
    cout << "\" is not initialized";

    return;
}


void SemanticError::PrintDUPLICATE_MODIFIER(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Duplicate specification of this modifier";

    return;
}


void SemanticError::PrintDUPLICATE_ACCESS_MODIFIER(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Duplicate specification of an access modifier. "
            "Only one instance of \"public\", \"private\", or \"protected\" may appear in a declaration";

    return;
}


void SemanticError::PrintINVALID_TOP_LEVEL_CLASS_MODIFIER(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    Unicode::Cout(err.insert1);
    cout << " is not a valid modifier for a top-level class";

    return;
}


void SemanticError::PrintINVALID_INNER_CLASS_MODIFIER(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    Unicode::Cout(err.insert1);
    cout << " is not a valid modifier for an inner class";

    return;
}


void SemanticError::PrintINVALID_STATIC_INNER_CLASS_MODIFIER(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    Unicode::Cout(err.insert1);
    cout << " is not a valid modifier for an inner class that is enclosed in an interface";

    return;
}


void SemanticError::PrintINVALID_LOCAL_CLASS_MODIFIER(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    Unicode::Cout(err.insert1);
    cout << " is not a valid modifier for a local inner class";

    return;
}


void SemanticError::PrintFINAL_ABSTRACT_CLASS(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A class may not be declared both \"final\" and \"abstract\"";

    return;
}


void SemanticError::PrintINVALID_INTERFACE_MODIFIER(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    Unicode::Cout(err.insert1);
    cout << " is not a valid interface modifier";

    return;
}


void SemanticError::PrintVOLATILE_FINAL(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A \"volatile\" field may not be declared \"final\"";

    return;
}


void SemanticError::PrintFINAL_VOLATILE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A \"final\" field may not be declared \"volatile\"";

    return;
}


void SemanticError::PrintINVALID_FIELD_MODIFIER(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    Unicode::Cout(err.insert1);
    cout << " is not a valid field modifier";

    return;
}


void SemanticError::PrintINVALID_LOCAL_MODIFIER(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    Unicode::Cout(err.insert1);
    cout << " is not a valid local variable or parameter modifier";

    return;
}


void SemanticError::PrintINVALID_METHOD_MODIFIER(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    Unicode::Cout(err.insert1);
    cout << " is not a valid method modifier";

    return;
}


void SemanticError::PrintINVALID_SIGNATURE_MODIFIER(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    Unicode::Cout(err.insert1);
    cout << " is not a valid signature modifier";

    return;
}


void SemanticError::PrintINVALID_CONSTRUCTOR_MODIFIER(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    Unicode::Cout(err.insert1);
    cout << " is not a valid constructor modifier";

    return;
}


void SemanticError::PrintINVALID_CONSTANT_MODIFIER(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    Unicode::Cout(err.insert1);
    cout << " is not a valid constant modifier";

    return;
}


void SemanticError::PrintPARENT_TYPE_IN_UNNAMED_PACKAGE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type associated with this construct is (or depends on) the type ";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    cout << " which is contained in an unnamed package";

    return;
}


void SemanticError::PrintRECOMPILATION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type associated with this construct depends on file ";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    cout << ".class which, in turn, depends on file ";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << "/";
    }
    Unicode::Cout(err.insert4);
    cout << ".java. All files that depend on this source file, in particular, ";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    cout << ".java should be recompiled";

    return;
}


void SemanticError::PrintTYPE_NOT_FOUND(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Type ";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    cout << " was not found";

    return;
}


void SemanticError::PrintDUPLICATE_ON_DEMAND_IMPORT(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Type ";
    Unicode::Cout(err.insert1);
    cout << " is imported on demand from package ";
    Unicode::Cout(err.insert2);
    cout << " and package ";
    Unicode::Cout(err.insert3);

    return;
}


void SemanticError::PrintNOT_A_TYPE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A type is expected here";

    return;
}


void SemanticError::PrintNOT_A_CLASS(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Interface \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << '/';
    }
    Unicode::Cout(err.insert2);
    cout << "\" cannot be used where a class is expected";

    return;
}


void SemanticError::PrintNOT_AN_INTERFACE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Class ";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << '/';
    }
    Unicode::Cout(err.insert2);
    cout << " cannot be used where an interface is expected";

    return;
}


void SemanticError::PrintSUPER_IS_FINAL(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The super class \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << '/';
    }
    Unicode::Cout(err.insert2);
    cout << "\" is final. A final class must not have subclasses";

    return;
}


void SemanticError::PrintOBJECT_WITH_SUPER_TYPE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type ";
    Unicode::Cout(err.insert1);
    cout << '/';
    Unicode::Cout(err.insert2);
    cout << " must not have a super type";

    return;
}


void SemanticError::PrintOBJECT_HAS_NO_SUPER_TYPE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type ";
    Unicode::Cout(err.insert1);
    cout << '/';
    Unicode::Cout(err.insert2);
    cout << " does not have a super type";

    return;
}


void SemanticError::PrintDUPLICATE_FIELD(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Duplicate declaration of field \"";
    Unicode::Cout(err.insert1);
    cout << "\" in type \"";
    Unicode::Cout(err.insert2);
    cout << "\"";

    return;
}


void SemanticError::PrintDUPLICATE_METHOD(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Duplicate declaration of method \"";
    Unicode::Cout(err.insert1);
    cout << "\" in type \"";
    Unicode::Cout(err.insert2);
    cout << "\"";

    return;
}


void SemanticError::PrintMISMATCHED_INHERITED_METHOD(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The return type of method \"";
    Unicode::Cout(err.insert1);
    cout << "\" does not match the return type of method \"";
    Unicode::Cout(err.insert2);
    cout << "\" inherited from type \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << "/";
    }
    Unicode::Cout(err.insert4);
    cout << "\"";

    return;
}


void SemanticError::PrintMISMATCHED_INHERITED_METHOD_EXTERNALLY(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "In class \"";
    Unicode::Cout(err.insert1);
    cout << "\", the method \"";
    Unicode::Cout(err.insert2);
    cout << "\", inherited from type \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << "/";
    }
    Unicode::Cout(err.insert4);
    cout << "\", does not have the same return type as the overridden method \"";
    Unicode::Cout(err.insert5);
    cout << "\", inherited from type \"";
    if (NotDot(err.insert6))
    {
        Unicode::Cout(err.insert6);
        cout << "/";
    }
    Unicode::Cout(err.insert7);
    cout << "\"";

    return;
}


void SemanticError::PrintDUPLICATE_CONSTRUCTOR(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Duplicate declaration of this constructor in type \"";
    Unicode::Cout(err.insert1);
    cout << "\"";

    return;
}


void SemanticError::PrintMISMATCHED_CONSTRUCTOR_NAME(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The name of the constructor \"";
    Unicode::Cout(err.insert1);
    cout << "\" does not match the name of the class \"";
    Unicode::Cout(err.insert2);
    cout << "\"";

    return;
}


void SemanticError::PrintMETHOD_WITH_CONSTRUCTOR_NAME(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The name of this method \"";
    Unicode::Cout(err.insert1);
    cout << "\" matches the name of the containing class. "
            "However, the method is not a constructor since it contains a return type";

    return;
}


void SemanticError::PrintDUPLICATE_FORMAL_PARAMETER(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Duplicate declaration of formal parameter ";
    Unicode::Cout(err.insert1);

    return;
}


void SemanticError::PrintDUPLICATE_LOCAL_VARIABLE_DECLARATION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Duplicate declaration of local variable \"";
    Unicode::Cout(err.insert1);
    cout << "\"";

    return;
}


void SemanticError::PrintDUPLICATE_LOCAL_TYPE_DECLARATION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Duplicate declaration of local class \"";
    Unicode::Cout(err.insert1);
    cout << "\". The other occurrence is at location ";
    Unicode::Cout(err.insert2);

    return;
}


void SemanticError::PrintMULTIPLE_DEFAULT_LABEL(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Multiple specification of default label in switch statement";

    return;
}


void SemanticError::PrintUNDECLARED_LABEL(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    Unicode::Cout(err.insert1);
    cout << " is an undeclared label";

    return;
}


void SemanticError::PrintDUPLICATE_LABEL(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Duplicate declaration of label \"";
    Unicode::Cout(err.insert1);
    cout << "\"";

    return;
}


void SemanticError::PrintTYPE_NOT_THROWABLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    cout << "\" is not a subclass of \"Throwable\"";

    return;
}


void SemanticError::PrintCATCH_PRIMITIVE_TYPE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A primitive type cannot be used to declare a catch clause parameter - the type Error is assumed";

    return;
}


void SemanticError::PrintCATCH_ARRAY_TYPE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A array type cannot be used to declare a catch clause parameter - the type Error is assumed";

    return;
}


void SemanticError::PrintAMBIGUOUS_NAME(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The name \"";
    Unicode::Cout(err.insert1);
    cout << "\" is an ambiguous name found in the types \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << "/";
    }
    Unicode::Cout(err.insert3);
    cout << "\" and \"";
    if (NotDot(err.insert4))
    {
        Unicode::Cout(err.insert4);
        cout << "/";
    }
    Unicode::Cout(err.insert5);
    cout << "\"";

    return;
}


void SemanticError::PrintFIELD_IS_TYPE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The name \"";
    Unicode::Cout(err.insert1);
    cout << "\" cannot be dereferenced as it represents a type";

    return;
}


void SemanticError::PrintFIELD_NOT_FOUND(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "No field named \"";
    Unicode::Cout(err.insert1);
    cout << "\" was found in type \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << "/";
    }
    Unicode::Cout(err.insert3);
    cout << "\"";

    return;
}


void SemanticError::PrintFIELD_NAME_MISSPELLED(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "No field named \"";
    Unicode::Cout(err.insert1);
    cout << "\" was found in type \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << "/";
    }
    Unicode::Cout(err.insert3);
    cout << "\". However, there is an accessible field \"";
    Unicode::Cout(err.insert4);
    cout << "\" whose name closely matches the name \"";
    Unicode::Cout(err.insert1);
    cout << "\"";

    return;
}


void SemanticError::PrintFIELD_WITH_PRIVATE_ACCESS_NOT_ACCESSIBLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The field \"";
    Unicode::Cout(err.insert1);
    cout << "\" contained in class \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << "/";
    }
    Unicode::Cout(err.insert3);
    cout << "\" has private access. Therefore, it is not accessible in class \"";
    if (NotDot(err.insert4))
    {
        Unicode::Cout(err.insert4);
        cout << "/";
    }
    Unicode::Cout(err.insert5);
    cout << "\"";

    return;
}


void SemanticError::PrintFIELD_WITH_DEFAULT_ACCESS_NOT_ACCESSIBLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The field \"";
    Unicode::Cout(err.insert1);
    cout << "\" contained in class \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << "/";
    }
    Unicode::Cout(err.insert3);
    cout << "\" has default access. Therefore, it is not accessible in class \"";
    if (NotDot(err.insert4))
    {
        Unicode::Cout(err.insert4);
        cout << "/";
    }
    Unicode::Cout(err.insert5);
    cout << "\" which is in a different package";

    return;
}


void SemanticError::PrintNAME_NOT_FOUND(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "No entity named \"";
    Unicode::Cout(err.insert1);
    cout << "\" was found in this environment";

    return;
}


void SemanticError::PrintNAME_NOT_YET_AVAILABLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Illegal use of name \"";
    Unicode::Cout(err.insert1);
    cout << "\" which has not yet been fully declared at this point";

    return;
}


void SemanticError::PrintNAME_NOT_VARIABLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The name \"";
    Unicode::Cout(err.insert1);
    cout << "\" does not denote a valid variable. If \"";
    Unicode::Cout(err.insert1);
    cout << "\" is a method that takes no argument, it must be followed by \"()\"";

    return;
}


void SemanticError::PrintMETHOD_NOT_FOUND(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "No match was found for method \"";
    Unicode::Cout(err.insert1);
    cout << "\"";

    return;
}


void SemanticError::PrintMETHOD_NAME_NOT_FOUND_IN_TYPE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "No method named \"";
    Unicode::Cout(err.insert1);
    cout << "\" was found in type \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << "/";
    }
    Unicode::Cout(err.insert3);
    cout << "\"";

    return;
}


void SemanticError::PrintMETHOD_NAME_MISSPELLED(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "No method named \"";
    Unicode::Cout(err.insert1);
    cout << "\" was found in type \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << "/";
    }
    Unicode::Cout(err.insert3);
    cout << "\". However, there is an accessible method \"";
    Unicode::Cout(err.insert4);
    cout << "\" whose name closely matches the name \"";
    Unicode::Cout(err.insert1);
    cout << "\"";

    return;
}


void SemanticError::PrintMETHOD_WITH_PRIVATE_ACCESS_NOT_ACCESSIBLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Method \"";
    Unicode::Cout(err.insert1);
    cout << "\" in class \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << "/";
    }
    Unicode::Cout(err.insert3);
    cout << "\" has private access. Therefore, it is not accessible in class \"";
    if (NotDot(err.insert4))
    {
        Unicode::Cout(err.insert4);
        cout << "/";
    }
    Unicode::Cout(err.insert5);
    cout << "\"";

    return;
}


void SemanticError::PrintMETHOD_WITH_DEFAULT_ACCESS_NOT_ACCESSIBLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Method \"";
    Unicode::Cout(err.insert1);
    cout << "\" in class \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << "/";
    }
    Unicode::Cout(err.insert3);
    cout << "\" has default access. Therefore, it is not accessible in class \"";
    if (NotDot(err.insert4))
    {
        Unicode::Cout(err.insert4);
        cout << "/";
    }
    Unicode::Cout(err.insert5);
    cout << "\" which is in a different package";

    return;
}


void SemanticError::PrintHIDDEN_METHOD_IN_ENCLOSING_CLASS(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The method \"";
    Unicode::Cout(err.insert1);
    cout << "\" contained in the enclosing type \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << "/";
    }
    Unicode::Cout(err.insert3);
    cout << "\" is a perfect match for this method call."
            " However, it is not visible in this nested class because a method with the same name is hiding it";

    return;
}


void SemanticError::PrintFIELD_NOT_METHOD(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The name \"";
    Unicode::Cout(err.insert1);
    cout << "\" is not a method name but the name of a field member of the type \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << "/";
    }
    Unicode::Cout(err.insert3);
    cout << "\"";

    return;
}


void SemanticError::PrintTYPE_NOT_METHOD(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The keyword \"new\" is expected before this expression as \"";
    Unicode::Cout(err.insert1);
    cout << "\" is not the name of a method but the name of a type";

    return;
}


void SemanticError::PrintTYPE_NOT_FIELD(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A type \"";
    Unicode::Cout(err.insert1);
    cout << "\" was found where a field name or method call was expected. Did you mean to write \"";
    Unicode::Cout(err.insert1);
    cout << ".xxx\", or \"new ";
    Unicode::Cout(err.insert1);
    cout << "()\", or ... ?";

    return;
}


void SemanticError::PrintMETHOD_NOT_FIELD(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The name \"";
    Unicode::Cout(err.insert1);
    cout << "\" is not a field name but the name of a method declared in the type \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << "/";
    }
    Unicode::Cout(err.insert3);
    cout << "\"";

    return;
}


void SemanticError::PrintAMBIGUOUS_CONSTRUCTOR_INVOCATION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Ambiguous invocation of constructor \"";
    Unicode::Cout(err.insert1);
    cout << "\"";

    return;
}


void SemanticError::PrintAMBIGUOUS_METHOD_INVOCATION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Ambiguous invocation of method \"";
    Unicode::Cout(err.insert1);
    cout << "\". At least two methods are accessible from here: Method \"";
    Unicode::Cout(err.insert2);
    cout << "\" declared in type \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << '/';
    }
    Unicode::Cout(err.insert4);
    cout << "\" and method \"";
    Unicode::Cout(err.insert5);
    cout << "\" declared in type \"";
    if (NotDot(err.insert6))
    {
        Unicode::Cout(err.insert6);
        cout << '/';
    }
    Unicode::Cout(err.insert7);
    cout << "\"";

    return;
}


void SemanticError::PrintNAME_NOT_CLASS_VARIABLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The name \"";
    Unicode::Cout(err.insert1);
    cout << "\" does not denote a class (static) variable";

    return;
}


void SemanticError::PrintNOT_A_NUMERIC_VARIABLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Only a variable of numeric type can appear in this context";

    return;
}


void SemanticError::PrintMETHOD_NOT_CLASS_METHOD(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The method \"";
    Unicode::Cout(err.insert1);
    cout << "\" does not denote a class method";

    return;
}


void SemanticError::PrintABSTRACT_TYPE_CREATION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Attempt to instantiate an abstract class \"";
    Unicode::Cout(err.insert1);
    cout << "\"";

    return;
}


void SemanticError::PrintCONSTRUCTOR_NOT_FOUND(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "No match was found for constructor \"";
    Unicode::Cout(err.insert1);
    cout << "\"";

    return;
} 


void SemanticError::PrintMETHOD_FOUND_FOR_CONSTRUCTOR(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "No match was found for constructor \"";
    Unicode::Cout(err.insert1);
    cout << "\". However, a method with the same name was found at location ";
    Unicode::Cout(err.insert2);

    return;
} 


void SemanticError::PrintINCOMPATIBLE_TYPE_FOR_INITIALIZATION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type of the left-hand side (or array type) in this initialization (or array creation expression), \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << '/';
    }
    Unicode::Cout(err.insert2);
    cout << "\", is not compatible with the type of the right-hand side expression, \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << '/';
    }
    Unicode::Cout(err.insert4);
    cout << "\"";

    return;
}


void SemanticError::PrintINCOMPATIBLE_TYPE_FOR_ASSIGNMENT(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type of the left-hand side in this assignment, \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << '/';
    }
    Unicode::Cout(err.insert2);
    cout << "\", is not compatible with the type of the right-hand side expression, \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << '/';
    }
    Unicode::Cout(err.insert4);
    cout << "\"";

    return;
}


void SemanticError::PrintINCOMPATIBLE_TYPE_FOR_CONDITIONAL_EXPRESSION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "In this conditional expression, the type of the false subexpression, \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << '/';
    }
    Unicode::Cout(err.insert2);
    cout << "\", is not compatible with the type of the true subexpression, \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << '/';
    }
    Unicode::Cout(err.insert4);
    cout << "\"";

    return;
}


void SemanticError::PrintVOID_ARRAY(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Arrays of type \"void\" are not legal";

    return;
}


void SemanticError::PrintVOID_TYPE_IN_EQUALITY_EXPRESSION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Subexpressions of type \"void\" may not appear in an EqualityExpression";

    return;
}


void SemanticError::PrintINCOMPATIBLE_TYPE_FOR_BINARY_EXPRESSION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type of the left-hand side expression, \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << '/';
    }
    Unicode::Cout(err.insert2);
    cout << "\", is not compatible with the type of the right-hand side expression, \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << '/';
    }
    Unicode::Cout(err.insert4);
    cout << "\" (and vice-versa)";

    return;
}


void SemanticError::PrintINVALID_INSTANCEOF_CONVERSION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type of the left-side expression, \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << '/';
    }
    Unicode::Cout(err.insert2);
    cout << "\", cannot possibly be an instance of type \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << '/';
    }
    Unicode::Cout(err.insert4);
    cout << "\"";

    return;
}


void SemanticError::PrintINVALID_CAST_CONVERSION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "An expression of type \"";
    Unicode::Cout(err.insert1);
    cout << "\" cannot be cast into type \"";
    Unicode::Cout(err.insert2);
    cout << "\"";

    return;
}


void SemanticError::PrintINVALID_CAST_TYPE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Expression found where a type is expected";

    return;
}


void SemanticError::PrintTYPE_NOT_PRIMITIVE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type of this expression, \"";
    Unicode::Cout(err.insert1);
    cout << "\", is not a primitive type";

    return;
}


void SemanticError::PrintTYPE_NOT_INTEGRAL(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type of this expression, \"";
    Unicode::Cout(err.insert1);
    cout << "\", is not an integral type";

    return;
}


void SemanticError::PrintTYPE_NOT_NUMERIC(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type of this expression, \"";
    Unicode::Cout(err.insert1);
    cout << "\", is not numeric";

    return;
}


void SemanticError::PrintTYPE_NOT_INTEGER(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type of this expression, \"";
    Unicode::Cout(err.insert1);
    cout << "\", cannot be promoted to \"int\" by widening conversion";

    return;
}


void SemanticError::PrintTYPE_NOT_BOOLEAN(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type of this expression, \"";
    Unicode::Cout(err.insert1);
    cout << "\", is not boolean";

    return;
}


void SemanticError::PrintTYPE_NOT_ARRAY(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type of this expression, \"";
    Unicode::Cout(err.insert1);
    cout << "\", is not an array type";

    return;
}


void SemanticError::PrintTYPE_NOT_REFERENCE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type of this expression, \"";
    Unicode::Cout(err.insert1);
    cout << "\", is not a valid reference type in this context";

    return;
}


void SemanticError::PrintTYPE_NOT_VALID_FOR_SWITCH(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type of a switch statement expression must be either \"int\", \"short\", \"char\" or \"byte\".";
    cout << " The type of this expression is \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << '/';
    }
    Unicode::Cout(err.insert2);
    cout << "\"";

    return;
}


void SemanticError::PrintTYPE_IS_VOID(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "An expression of type \"";
    Unicode::Cout(err.insert1);
    cout << "\" is not valid in this context";

    return;
}


void SemanticError::PrintVALUE_NOT_REPRESENTABLE_IN_TYPE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The value of this expression cannot be represented in type \"";
    Unicode::Cout(err.insert1);
    cout << "\"";

    return;
}


void SemanticError::PrintDUPLICATE_CASE_VALUE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The value of this expression, ";
    Unicode::Cout(err.insert1);
    cout << ", has already been used in this switch statement";

    return;
}


void SemanticError::PrintMISPLACED_THIS_EXPRESSION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A \"this\" expression may only be used in the body of an instance method, "
            "constructor (after the explicit constructor invocation, if any), "
            "initializer block, or in the initializer expression of an instance variable";

    return;
}


void SemanticError::PrintMISPLACED_SUPER_EXPRESSION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A \"super\" expression may only appear in the body of a class that has a super class and"
            " it must be enclosed in the body of an instance method or constructor or in the initializer"
            " of an instance variable";

    return;
}


void SemanticError::PrintFINAL_VARIABLE_TARGET_IN_LOOP(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Possible attempt to assign a value to a final variable \"";
    Unicode::Cout(err.insert1);
    cout << "\"";
    cout << ", within the body of a loop that may execute more than once";

    return;
}


void SemanticError::PrintTARGET_VARIABLE_IS_FINAL(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Possible attempt to reassign a value to the final variable \"";
    Unicode::Cout(err.insert1);
    cout << "\"";
    if (err.insert2)
    {
        cout << ". The other assignement was at location ";
        Unicode::Cout(err.insert2);
    }

    return;
}


void SemanticError::PrintUNINITIALIZED_FINAL_VARIABLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A final variable must be initialized";

    return;
}


void SemanticError::PrintUNINITIALIZED_STATIC_FINAL_VARIABLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A blank class final variable must be initialized in a static initializer block. It is assumed to be initialized";

    return;
}


void SemanticError::PrintUNINITIALIZED_FINAL_VARIABLE_IN_CONSTRUCTOR(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The blank final field \"this.";
    cout << err.insert1;
    cout << "\" is not definitely assigned a value in this constructor";

    return;
}


void SemanticError::PrintINIT_SCALAR_WITH_ARRAY(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "An array initializer cannot be used to initialize a variable of type \"";
    Unicode::Cout(err.insert1);
    cout << "\"";

    return;
}


void SemanticError::PrintINIT_ARRAY_WITH_SCALAR(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A single expression cannot be used to initialize an array variable of type \"";
    Unicode::Cout(err.insert1);
    cout << "\"";

    return;
}


void SemanticError::PrintINVALID_BYTE_VALUE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A byte value must be an integer value (note that a character literal is not an integer value) in the range -128..127";

    return;
}


void SemanticError::PrintINVALID_SHORT_VALUE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A short value must be an integer value (note that a character literal is not an integer value) in the range -32768..32767";

    return;
}


void SemanticError::PrintINVALID_CHARACTER_VALUE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A character literal must be a valid unicode value - i.e., a character literal enclosed in single quotes or "
            "an integer value in the range 0..65535 or an escaped 3-digit octal value in the range \\000..\\377";

    return;
}


void SemanticError::PrintINVALID_INT_VALUE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The value of an \"int\" literal must be a decimal value in the range -2147483648..2147483647"
            " or a hexadecimal or octal literal that fits in 32 bits";

    return;
}


void SemanticError::PrintINVALID_LONG_VALUE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The value of a long literal must be a decimal value in the range "
            "-9223372036854775808..9223372036854775807 or a hexadecimal or octal literal that fits in 64 bits";

    return;
}


void SemanticError::PrintINVALID_FLOAT_VALUE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Invalid floating-point constant";

    return;
}


void SemanticError::PrintINVALID_DOUBLE_VALUE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Invalid double constant";

    return;
}


void SemanticError::PrintINVALID_STRING_VALUE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The value of this \"String\" literal is invalid. Perhaps it contains a bad escape sequence?";

    return;
}


void SemanticError::PrintRETURN_STATEMENT_IN_INITIALIZER(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A return statement may not appear in an initializer block";

    return;
}


void SemanticError::PrintMISPLACED_RETURN_WITH_EXPRESSION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A return statement with expression must be contained in a method declaration that is "
            "declared to return a value";

    return;
}


void SemanticError::PrintMISPLACED_RETURN_WITH_NO_EXPRESSION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A return statement with no expression may only appear in void method or a constructor";

    return;
}


void SemanticError::PrintMISMATCHED_RETURN_AND_METHOD_TYPE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type of this return expression, \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << '/';
    }
    Unicode::Cout(err.insert2);
    cout << "\", does not match the return type of the method, \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << '/';
    }
    Unicode::Cout(err.insert4);
    cout << "\"";

    return;
}


void SemanticError::PrintEXPRESSION_NOT_THROWABLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The expression in a throw statement must denote a variable or value of a reference type "
            "which is assignable to the type Throwable";

    return;
}


void SemanticError::PrintBAD_THROWABLE_EXPRESSION_IN_TRY(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type of the expression in this throw statement, \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << '/';
    }
    Unicode::Cout(err.insert2);
    cout << "\", is not catchable by the enclosing try statement;";
    if (wcslen(err.insert3) > 0)
    {
        cout << " nor is it assignable to an exception in the throws clause of the enclosing method or constructor \"";
        Unicode::Cout(err.insert3);
        cout << "\";";
    }
    cout << " nor is it a subclass of RuntimeException or Error";

    return;
}


void SemanticError::PrintBAD_THROWABLE_EXPRESSION_IN_METHOD(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type of the expression in this throw statement, \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << '/';
    }
    Unicode::Cout(err.insert2);
    cout << "\", is not assignable to an exception in the throws clause of the enclosing method or constructor \"";
    Unicode::Cout(err.insert3);
    cout << "\"; nor is it a subclass of RuntimeException or Error";

    return;
}


void SemanticError::PrintBAD_THROWABLE_EXPRESSION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type of the expression in this throw statement, \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << '/';
    }
    Unicode::Cout(err.insert2);
    cout << "\", is not a subclass of RuntimeException or Error";

    return;
}


void SemanticError::PrintMISPLACED_BREAK_STATEMENT(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A \"break\" statement must be enclosed in a \"switch\", \"while\", \"do\" or \"for\" statement";

    return;
}


void SemanticError::PrintMISPLACED_CONTINUE_STATEMENT(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A \"continue\" statement must be enclosed in a \"while\", \"do\" or \"for\" statement";

    return;
}


void SemanticError::PrintMISPLACED_EXPLICIT_CONSTRUCTOR_INVOCATION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Misplaced explicit constructor invocation";

    return;
}


void SemanticError::PrintINVALID_CONTINUE_TARGET(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The statement labeled \"";
    Unicode::Cout(err.insert1);
    cout << "\" cannot be continued since it is not a \"while\", \"do\" or \"for\" statement";

    return;
}


void SemanticError::PrintNON_ABSTRACT_TYPE_CONTAINS_ABSTRACT_METHOD(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The abstract method \"";
    Unicode::Cout(err.insert1);
    cout << "\" is enclosed in a type, \"";
    Unicode::Cout(err.insert2);
    cout << "\", that is not abstract";

    return;
}


void SemanticError::PrintNON_ABSTRACT_TYPE_INHERITS_ABSTRACT_METHOD(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The abstract method \"";
    Unicode::Cout(err.insert1);
    cout << "\", inherited from class \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << '/';
    }
    Unicode::Cout(err.insert3);
    cout << "\", is not implemented in the non-abstract class \"";
    if (NotDot(err.insert4))
    {
        Unicode::Cout(err.insert4);
        cout << '/';
    }
    Unicode::Cout(err.insert5);
    cout << "\"";

    return;
}


void SemanticError::PrintNON_ABSTRACT_TYPE_INHERITS_ABSTRACT_METHOD_FROM_ABSTRACT_CLASS(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The abstract method \"";
    Unicode::Cout(err.insert1);
    cout << "\", inherited from class \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << '/';
    }
    Unicode::Cout(err.insert3);
    cout << "\", is not implemented in the non-abstract class \"";
    if (NotDot(err.insert4))
    {
        Unicode::Cout(err.insert4);
        cout << '/';
    }
    Unicode::Cout(err.insert5);
    cout << "\". Since the type \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << '/';
    }
    Unicode::Cout(err.insert3);
    cout << "\" was read from a class file, it is possible that it just needs to be recompiled "
            "because after having inherited method \"";
    Unicode::Cout(err.insert1);
    cout << "\" from an interface, the method was subsequently removed from that interface.";

    return;
}


void SemanticError::PrintNON_ABSTRACT_TYPE_CANNOT_OVERRIDE_DEFAULT_ABSTRACT_METHOD(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The abstract method \"";
    Unicode::Cout(err.insert1);
    cout << "\", belonging to the class \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << '/';
    }
    Unicode::Cout(err.insert3);
    cout << "\" has default access."
            " Therefore, it is not inherited and hence, it cannot be implemented in the non-abstract class \"";
    if (NotDot(err.insert4))
    {
        Unicode::Cout(err.insert4);
        cout << '/';
    }
    Unicode::Cout(err.insert5);
    cout << "\"";

    return;
}


void SemanticError::PrintNO_ABSTRACT_METHOD_IMPLEMENTATION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "No implementation of the abstract method \"";
    Unicode::Cout(err.insert1);
    cout << "\" declared in type \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << '/';
    }
    Unicode::Cout(err.insert3);
    cout << "\" was found in class \"";
    Unicode::Cout(err.insert4);
    cout << "\"";

    return;
}


void SemanticError::PrintDUPLICATE_INTERFACE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Duplicate specification of interface \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << '/';
    }
    Unicode::Cout(err.insert2);
    cout << "\" in definition of type \"";
    Unicode::Cout(err.insert3);
    cout << "\"";

    return;
}


void SemanticError::PrintUNKNOWN_QUALIFIED_NAME_BASE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "\"";
    Unicode::Cout(err.insert1);
    cout << "\" is either a misplaced package name or a non-existent entity.";

    return;
}


void SemanticError::PrintUNKNOWN_AMBIGUOUS_NAME(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "\"";
    Unicode::Cout(err.insert1);
    cout << "\" is either a misplaced package name or a non-existent entity. An expression name is expected in this context";

    return;
}


void SemanticError::PrintCIRCULAR_CLASS(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The class \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    cout << "\" is circularly defined with its super type(s)";

    return;
}


void SemanticError::PrintCIRCULAR_INTERFACE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The interface \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    cout << "\" is circularly defined with its super type(s)";

    return;
}


void SemanticError::PrintTYPE_NOT_ACCESSIBLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << '/';
    }
    Unicode::Cout(err.insert2);
    cout << "\" with ";
    Unicode::Cout(err.insert3);
    cout << " access is not visible here";

    return;
}


void SemanticError::PrintPRIVATE_FIELD_NOT_ACCESSIBLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The field \"";
    Unicode::Cout(err.insert1);
    cout << "\" in type \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << '/';
    }
    Unicode::Cout(err.insert3);
    cout << "\" is private and not accessible here";

    return;
}


void SemanticError::PrintPROTECTED_FIELD_NOT_ACCESSIBLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The field \"";
    Unicode::Cout(err.insert1);
    cout << "\" in type \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << '/';
    }
    Unicode::Cout(err.insert3);
    cout << "\" is protected and not accessible here";

    return;
}


void SemanticError::PrintDEFAULT_FIELD_NOT_ACCESSIBLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The field \"";
    Unicode::Cout(err.insert1);
    cout << "\" in type \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << '/';
    }
    Unicode::Cout(err.insert3);
    cout << "\" has default access and is not accessible here";

    return;
}


void SemanticError::PrintPRIVATE_METHOD_NOT_ACCESSIBLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Method \"";
    Unicode::Cout(err.insert1);
    cout << "\" in type \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << '/';
    }
    Unicode::Cout(err.insert3);
    cout << "\" is private and not accessible here";

    return;
}


void SemanticError::PrintPROTECTED_METHOD_NOT_ACCESSIBLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Method \"";
    Unicode::Cout(err.insert1);
    cout << "\" in type \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << '/';
    }
    Unicode::Cout(err.insert3);
    cout << "\" is protected and not accessible here";

    return;
}


void SemanticError::PrintDEFAULT_METHOD_NOT_ACCESSIBLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Method \"";
    Unicode::Cout(err.insert1);
    cout << "\" in type \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << '/';
    }
    Unicode::Cout(err.insert3);
    cout << "\" has default access and is not accessible here";

    return;
}


void SemanticError::PrintPRIVATE_CONSTRUCTOR_NOT_ACCESSIBLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The constructor \"";
    Unicode::Cout(err.insert1);
    cout << "\" in type \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << '/';
    }
    Unicode::Cout(err.insert3);
    cout << "\" is private. Therefore, it is not accessible here";

    return;
}


void SemanticError::PrintPROTECTED_CONSTRUCTOR_NOT_ACCESSIBLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The constructor \"";
    Unicode::Cout(err.insert1);
    cout << "\" in type \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << '/';
    }
    Unicode::Cout(err.insert3);
    cout << "\" is protected. Therefore, it is not accessible here";

    return;
}


void SemanticError::PrintDEFAULT_CONSTRUCTOR_NOT_ACCESSIBLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The constructor \"";
    Unicode::Cout(err.insert1);
    cout << "\" in type \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << '/';
    }
    Unicode::Cout(err.insert3);
    cout << "\" has default access. Therefore, it is not accessible here";

    return;
}


void SemanticError::PrintCONSTRUCTOR_DOES_NOT_THROW_THIS_EXCEPTION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The constructor invoked here can throw the exception \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    cout << "\" which is not thrown by the constructor containing this call";

    return;
}


void SemanticError::PrintCONSTRUCTOR_DOES_NOT_THROW_SUPER_EXCEPTION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A constructor associated with this ";

    if (wcslen(err.insert1) == 0)
        cout << "anonymous type";
    else
    {
        cout << "type, \"";
        Unicode::Cout(err.insert1);
        cout << "\",";
    }

    cout << " does not throw the exception \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << "/";
    }
    Unicode::Cout(err.insert3);
    cout << "\" thrown by its super type, \"";
    if (NotDot(err.insert4))
    {
        Unicode::Cout(err.insert4);
        cout << "/";
    }
    Unicode::Cout(err.insert5);
    cout << "\"";

    return;
}


void SemanticError::PrintPARAMETER_REDECLARED(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The name of a formal parameter, \"";
    Unicode::Cout(err.insert1);
    cout << "\", may not be used to declare a local variable or an exception parameter";

    return;
}


void SemanticError::PrintBAD_ABSTRACT_METHOD_MODIFIER(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A method declaration that contains the keyword \"abstract\" may not also contain one of the keywords: "
            "\"private\", \"static\", \"final\", \"native\" or \"synchronized\"";

    return;
}


void SemanticError::PrintABSTRACT_METHOD_MODIFIER_CONFLICT(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "An abstract method may not also contain the keyword \"";
    Unicode::Cout(err.insert1);
    cout << "\"";

    return;
}


void SemanticError::PrintABSTRACT_METHOD_INVOCATION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "An abstract method, \"";
    Unicode::Cout(err.insert1);
    cout << "\", cannot be invoked";

    return;
}


void SemanticError::PrintFINAL_METHOD_OVERRIDE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The method \"";
    Unicode::Cout(err.insert1);
    cout << "\" cannot override the final (or private) method \"";
    Unicode::Cout(err.insert2);
    cout << "\" declared in type \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << "/";
    }
    Unicode::Cout(err.insert4);
    cout << "\"";

    return;
}


void SemanticError::PrintFINAL_METHOD_OVERRIDE_EXTERNALLY(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "In class \"";
    Unicode::Cout(err.insert1);
    cout << "\", the method \"";
    Unicode::Cout(err.insert2);
    cout << "\", inherited from type \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << "/";
    }
    Unicode::Cout(err.insert4);
    cout << "\", overrides the final (or private) method \"";
    Unicode::Cout(err.insert5);
    cout << "\", inherited from type \"";
    if (NotDot(err.insert6))
    {
        Unicode::Cout(err.insert6);
        cout << "/";
    }
    Unicode::Cout(err.insert7);
    cout << "\"";

    return;
}


void SemanticError::PrintPRIVATE_METHOD_OVERRIDE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The method \"";
    Unicode::Cout(err.insert1);
    cout << "\" is overriding the private (should be treated as final) method \"";
    Unicode::Cout(err.insert2);
    cout << "\" declared in type \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << "/";
    }
    Unicode::Cout(err.insert4);
    cout << "\"";

    return;
}


void SemanticError::PrintPRIVATE_METHOD_OVERRIDE_EXTERNALLY(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "In class \"";
    Unicode::Cout(err.insert1);
    cout << "\", the method \"";
    Unicode::Cout(err.insert2);
    cout << "\", inherited from type \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << "/";
    }
    Unicode::Cout(err.insert4);
    cout << "\", overrides the private (should be treated as final) method \"";
    Unicode::Cout(err.insert5);
    cout << "\", inherited from type \"";
    if (NotDot(err.insert6))
    {
        Unicode::Cout(err.insert6);
        cout << "/";
    }
    Unicode::Cout(err.insert7);
    cout << "\"";

    return;
}


void SemanticError::PrintCLASS_METHOD_OVERRIDE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The instance method \"";
    Unicode::Cout(err.insert1);
    cout << "\" cannot override the static method \"";
    Unicode::Cout(err.insert2);
    cout << "\" declared in type \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << "/";
    }
    Unicode::Cout(err.insert4);
    cout << "\"";

    return;
}


void SemanticError::PrintCLASS_METHOD_OVERRIDE_EXTERNALLY(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "In class \"";
    Unicode::Cout(err.insert1);
    cout << "\", the instance method \"";
    Unicode::Cout(err.insert2);
    cout << "\", inherited from type \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << "/";
    }
    Unicode::Cout(err.insert4);
    cout << "\", cannot override the static method \"";
    Unicode::Cout(err.insert5);
    cout << "\", declared in type \"";
    if (NotDot(err.insert6))
    {
        Unicode::Cout(err.insert6);
        cout << "/";
    }
    Unicode::Cout(err.insert7);
    cout << "\"";

    return;
}


void SemanticError::PrintINSTANCE_METHOD_OVERRIDE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The static method \"";
    Unicode::Cout(err.insert1);
    cout << "\" cannot hide the instance method \"";
    Unicode::Cout(err.insert2);
    cout << "\" declared in \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << "/";
    }
    Unicode::Cout(err.insert4);
    cout << "\"";

    return;
}


void SemanticError::PrintINSTANCE_METHOD_OVERRIDE_EXTERNALLY(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "In class \"";
    Unicode::Cout(err.insert1);
    cout << "\", the static method \"";
    Unicode::Cout(err.insert2);
    cout << "\", inherited from type \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << "/";
    }
    Unicode::Cout(err.insert4);
    cout << "\", hides the instance method \"";
    Unicode::Cout(err.insert5);
    cout << "\", declared in type \"";
    if (NotDot(err.insert6))
    {
        Unicode::Cout(err.insert6);
        cout << "/";
    }
    Unicode::Cout(err.insert7);
    cout << "\"";

    return;
}


void SemanticError::PrintBAD_ACCESS_METHOD_OVERRIDE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The method \"";
    Unicode::Cout(err.insert1);
    cout << "\" with ";
    Unicode::Cout(err.insert2);
    cout << " access cannot override the method \"";
    Unicode::Cout(err.insert3);
    cout << "\" with ";
    Unicode::Cout(err.insert4);
    cout << " access declared in type \"";
    if (NotDot(err.insert5))
    {
        Unicode::Cout(err.insert5);
        cout << "/";
    }
    Unicode::Cout(err.insert6);
    cout << "\"";

    return;
}


void SemanticError::PrintBAD_ACCESS_METHOD_OVERRIDE_EXTERNALLY(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "In class \"";
    Unicode::Cout(err.insert1);
    cout << "\", the method \"";
    Unicode::Cout(err.insert2);
    cout << "\" with ";
    Unicode::Cout(err.insert3);
    cout << " access inherited from type \"";
    if (NotDot(err.insert4))
    {
        Unicode::Cout(err.insert4);
        cout << "/";
    }
    Unicode::Cout(err.insert5);
    cout << "\", cannot override the method \"";
    Unicode::Cout(err.insert6);
    cout << "\" with ";
    Unicode::Cout(err.insert7);
    cout << " access inherited from type \"";
    if (NotDot(err.insert8))
    {
        Unicode::Cout(err.insert8);
        cout << "/";
    }
    Unicode::Cout(err.insert9);
    cout << "\"";

    return;
}


void SemanticError::PrintMISMATCHED_OVERRIDDEN_EXCEPTION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The exception \"";
    Unicode::Cout(err.insert1);
    cout << "\" is not the same as or a subclass of any exception in the throws clause of the overridden method \"";
    Unicode::Cout(err.insert2);
    cout << "\" declared in type \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << "/";
    }
    Unicode::Cout(err.insert4);
    cout << "\"";

    return;
}


void SemanticError::PrintMISMATCHED_OVERRIDDEN_EXCEPTION_EXTERNALLY(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "In class \"";
    Unicode::Cout(err.insert1);
    cout << "\", the exception \"";
    Unicode::Cout(err.insert2);
    cout << "\" specified in method \"";
    Unicode::Cout(err.insert3);
    cout << "\" inherited from type \"";
    if (NotDot(err.insert4))
    {
        Unicode::Cout(err.insert4);
        cout << "/";
    }
    Unicode::Cout(err.insert5);
    cout << "\", is not the same as or a subclass of any exception in the throws clause of the overridden method \"";
    Unicode::Cout(err.insert6);
    cout << "\" declared in type \"";
    if (NotDot(err.insert7))
    {
        Unicode::Cout(err.insert7);
        cout << "/";
    }
    Unicode::Cout(err.insert8);
    cout << "\"";

    return;
}


void SemanticError::PrintABSTRACT_METHOD_WITH_BODY(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The declaration of the abstract or native method, \"";
    Unicode::Cout(err.insert1);
    cout << "\", must not contain a method body";

    return;
}


void SemanticError::PrintNON_ABSTRACT_METHOD_WITHOUT_BODY(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The declaration of the non-abstract and non-native method, \"";
    Unicode::Cout(err.insert1);
    cout << "\", must contain a method body";

    return;
}


void SemanticError::PrintSTATIC_OVERRIDE_ABSTRACT(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The static method \"";
    Unicode::Cout(err.insert1);
    cout << "\" cannot hide an abstract method of the same name declared in type \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << "/";
    }
    Unicode::Cout(err.insert3);
    cout << "\"";

    return;
}


void SemanticError::PrintSTATIC_OVERRIDE_ABSTRACT_EXTERNALLY(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "In class \"";
    Unicode::Cout(err.insert1);
    cout << "\", the static method \"";
    Unicode::Cout(err.insert2);
    cout << "\", inherited from type \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << "/";
    }
    Unicode::Cout(err.insert4);
    cout << "\", cannot hide the abstract method \"";
    Unicode::Cout(err.insert5);
    cout << "\", inherited from type \"";
    if (NotDot(err.insert6))
    {
        Unicode::Cout(err.insert6);
        cout << "/";
    }
    Unicode::Cout(err.insert7);
    cout << "\"";

    return;
}


void SemanticError::PrintCIRCULAR_THIS_CALL(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The constructor \"";
    Unicode::Cout(err.insert1);
    cout << "\" may not directly or indirectly invoke itself";

    return;
}


void SemanticError::PrintINSTANCE_VARIABLE_IN_EXPLICIT_CONSTRUCTOR_INVOCATION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The instance variable \"";
    Unicode::Cout(err.insert1);
    cout << "\" declared in class \"";
    Unicode::Cout(err.insert2);
    cout << "\" is not accessible in an explicit constructor invocation";

    return;
}


void SemanticError::PrintINSTANCE_METHOD_IN_EXPLICIT_CONSTRUCTOR_INVOCATION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The instance method \"";
    Unicode::Cout(err.insert1);
    cout << "\" declared in this class, \"";
    Unicode::Cout(err.insert2);
    cout << "\", or one of its super classes, is not accessible in an explicit constructor invocation";

    return;
}


void SemanticError::PrintSYNTHETIC_VARIABLE_ACCESS(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Illegal attempt to access the synthetic field \"";
    Unicode::Cout(err.insert1);
    cout << "\" contained in class \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << "/";
    }
    Unicode::Cout(err.insert3);
    cout << "\"";

    return;
}


void SemanticError::PrintSYNTHETIC_METHOD_INVOCATION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Illegal attempt to invoke the synthetic method \"";
    Unicode::Cout(err.insert1);
    cout << "\" contained in class \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << "/";
    }
    Unicode::Cout(err.insert3);
    cout << "\"";

    return;
}


void SemanticError::PrintTHIS_IN_EXPLICIT_CONSTRUCTOR_INVOCATION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The expression \"";
    Unicode::Cout(err.insert1);
    cout << "\" may not be used in an explicit constructor invocation";

    return;
}


void SemanticError::PrintSUPER_IN_EXPLICIT_CONSTRUCTOR_INVOCATION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The expression \"";
    Unicode::Cout(err.insert1);
    cout << "\" may not be used in an explicit constructor invocation";

    return;
}


void SemanticError::PrintEXPRESSION_NOT_CONSTANT(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "A constant expression is expected in this context";

    return;
}


void SemanticError::PrintUNCATCHABLE_METHOD_THROWN_CHECKED_EXCEPTION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The method \"";
    Unicode::Cout(err.insert1);
    cout << "\" can throw the checked exception \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << "/";
    }
    Unicode::Cout(err.insert3);
    cout << "\", but its invocation is neither enclosed in a try statement that can catch "
            "that exception nor in the body of a method or constructor that \"throws\" that exception";

    return;
}


void SemanticError::PrintUNCATCHABLE_CONSTRUCTOR_THROWN_CHECKED_EXCEPTION(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The constructor \"";
    Unicode::Cout(err.insert1);
    cout << "\" can throw the checked exception \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << "/";
    }
    Unicode::Cout(err.insert3);
    cout << "\", but its invocation is neither enclosed in a try statement that can catch "
            "that exception nor in the body of a method or constructor that \"throws\" that exception";

    return;
}


void SemanticError::PrintUNREACHABLE_CATCH_CLAUSE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "This catch block may be unreachable because there is no exception "
            "whose type is assignable to \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    cout << "\" that can be thrown during execution of the body of the try block";

    return;
}


void SemanticError::PrintUNREACHABLE_STATEMENT(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "This statement is unreachable";

    return;
}


void SemanticError::PrintUNREACHABLE_STATEMENTS(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "These statements are unreachable";

    return;
}


void SemanticError::PrintUNREACHABLE_CONSTRUCTOR_BODY(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The body of this constructor is unreachable because the last initializer block in this class does not complete normally";

    return;
}


void SemanticError::PrintBLOCKED_CATCH_CLAUSE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "This catch block is unreachable: the exception \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    cout << "\" was used in a previous catch clause in this try statement at location ";
    Unicode::Cout(err.insert3);

    return;
}


void SemanticError::PrintVARIABLE_NOT_DEFINITELY_ASSIGNED(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The variable \"";
    Unicode::Cout(err.insert1);
    cout << "\" may be accessed here before having been definitely assigned a value";

    return;
}


void SemanticError::PrintTYPED_METHOD_WITH_NO_RETURN(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The method \"";
    Unicode::Cout(err.insert1);
    cout << "\" must contain a return statement with an expression compatible with type \"";
    Unicode::Cout(err.insert2);
    cout << "\"";

    return;
}


void SemanticError::PrintDEFAULT_METHOD_NOT_OVERRIDDEN(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Method \"";
    Unicode::Cout(err.insert1);
    cout << "\" in class \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << "/";
    }
    Unicode::Cout(err.insert3);
    cout << "\" does not override the corresponding method with default access in class \"";
    if (NotDot(err.insert4))
    {
        Unicode::Cout(err.insert4);
        cout << "/";
    }
    Unicode::Cout(err.insert5);
    cout << "\"";

    return;
}


void SemanticError::PrintTYPE_NOT_IN_UNNAMED_PACKAGE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The file \"";
    Unicode::Cout(err.insert1);
    cout << ".class\" was found in directory \"";
    Unicode::Cout(err.insert2);
    cout << "\" specified in the CLASSPATH. However, that class file specifies a type associated with the named package \"";
    Unicode::Cout(err.insert3);
    cout << "\" instead of the unnamed package";
}


void SemanticError::PrintTYPE_IN_WRONG_PACKAGE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type \"";
    Unicode::Cout(err.insert1);
    cout << "\" was found in package \"";
    Unicode::Cout(err.insert2);
    cout << "\". However, that type is associated with ";
    if (wcslen(err.insert3) == 0)
        cout << "the unnamed package";
    else
    {
        cout << "another named package, \"";
        Unicode::Cout(err.insert3);
        cout << "\"";
    }
}


void SemanticError::PrintTYPE_NAME_MISMATCH(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The name of the type specified, \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    cout << "\", does not match the name found in the class file: \"";
    Unicode::Cout(err.insert3);
    cout << "\"";
}


void SemanticError::PrintONE_UNNAMED_PACKAGE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type \"";
    Unicode::Cout(err.insert1);
    cout << "\" was found in directory \"";
    Unicode::Cout(err.insert2);
    cout << "\" specified in the CLASSPATH. It is accessible here only because, by default, this compiler uses "
            "one unnamed package. In a compiler that associates an unnamed package with each directory "
            "(as this compiler does with the +P option) this access would be illegal";

    return;
}



void SemanticError::PrintCOMPRESSED_ZIP_FILE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The file ";
    Unicode::Cout(err.insert1);
    cout << "(";
    Unicode::Cout(err.insert2);
    cout << "/";
    Unicode::Cout(err.insert3);
    cout << ") is in an unsupported compressed format. (Unzip and) Rezip \"";
    Unicode::Cout(err.insert1);
    cout << "\"";

    return;
}


void SemanticError::PrintINVALID_CLASS_FILE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The class file \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    cout << ".class\" has an invalid format";

    return;
}


void SemanticError::PrintCANNOT_OPEN_CLASS_FILE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Unable to open file associated with type \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    cout << "\"";

    return;
}


void SemanticError::PrintONE_ONE_FEATURE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "This is a 1.1 feature";

    return;
}


void SemanticError::PrintSTATIC_NOT_INNER_CLASS(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The static class \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    cout << "\" is not an inner class";

    return;
}


void SemanticError::PrintTYPE_NOT_INNER_CLASS(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    cout << "\", is not an inner class that is immediately enclosed in type \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << "/";
    }
    Unicode::Cout(err.insert4);
    cout << "\"";

    return;
}


void SemanticError::PrintSUPER_TYPE_NOT_INNER_CLASS(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The super type \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    cout << "\" of this type, \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << "/";
    }
    Unicode::Cout(err.insert4);
    cout << "\", is not an inner class that is immediately enclosed in type \"";
    if (NotDot(err.insert5))
    {
        Unicode::Cout(err.insert5);
        cout << "/";
    }
    Unicode::Cout(err.insert6);
    cout << "\"";

    return;
}


void SemanticError::PrintSTATIC_FIELD_IN_INNER_CLASS(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "An inner class may not contain a static field that is not final";

    return;
}


void SemanticError::PrintSTATIC_METHOD_IN_INNER_CLASS(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Inner class may not contain static method";

    return;
}


void SemanticError::PrintSTATIC_TYPE_IN_INNER_CLASS(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The static type \"";
    Unicode::Cout(err.insert1);
    cout << "\" is enclosed in an inner class, \"";
    Unicode::Cout(err.insert2);
    cout << "\", located at ";
    Unicode::Cout(err.insert3);

    return;
}


void SemanticError::PrintSTATIC_INITIALIZER_IN_INNER_CLASS(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "This static initializer is enclosed in an inner class, \"";
    Unicode::Cout(err.insert1);
    cout << "\", located at ";
    Unicode::Cout(err.insert2);

    return;
}



void SemanticError::PrintINNER_CLASS_REFERENCE_TO_NON_FINAL_LOCAL_VARIABLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Invalid reference in inner class \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    cout << "\" to a non-final local variable, \"";
    Unicode::Cout(err.insert3);
    cout << "\", declared in method \"";
    Unicode::Cout(err.insert4);
    cout << "\"";

    return;
}


void SemanticError::PrintINHERITANCE_AND_LEXICAL_SCOPING_CONFLICT_WITH_LOCAL(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Ambiguous reference to field \"";
    Unicode::Cout(err.insert1);
    cout << "\" declared in (or inherited from) type \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << "/";
    }
    Unicode::Cout(err.insert3);
    cout << "\" but also declared in the enclosing method \"";
    Unicode::Cout(err.insert4);
    cout << "\". Explicit qualification is required";

    return;
}

void SemanticError::PrintINHERITANCE_AND_LEXICAL_SCOPING_CONFLICT_WITH_MEMBER(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Ambiguous reference to member named \"";
    Unicode::Cout(err.insert1);
    cout << "\" inherited from type \"";
    if (NotDot(err.insert2))
    {
        Unicode::Cout(err.insert2);
        cout << "/";
    }
    Unicode::Cout(err.insert3);
    cout << "\" but also declared or inherited in the enclosing type \"";
    if (NotDot(err.insert4))
    {
        Unicode::Cout(err.insert4);
        cout << "/";
    }
    Unicode::Cout(err.insert5);
    cout << "\". Explicit qualification is required";

    return;
}


void SemanticError::PrintILLEGAL_THIS_FIELD_ACCESS(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The type \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    cout << "\" is either not an outer type of type \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << "/";
    }
    Unicode::Cout(err.insert4);
    cout << "\" or it is not accessible because this expression appears in a static region";

    return;
}


void SemanticError::PrintENCLOSING_INSTANCE_NOT_ACCESSIBLE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "An instance of \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    Unicode::Cout(StringConstant::US__DO_);
    Unicode::Cout(StringConstant::US_this);
    cout << "\" is not accessible here";
    cout << ". In general, an enclosing instance is accessible only in the body of an instance method, "
            "constructor (after the explicit constructor invocation, if any), "
            "initializer block, or in the initializer expression of an instance variable";
    return;
}


void SemanticError::PrintZERO_DIVIDE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Attempt to divide by zero";
}


void SemanticError::PrintVOID_TO_STRING(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Attempt to convert an expression of type void into a String";
}


void SemanticError::PrintINVALID_ENCLOSING_INSTANCE(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "The super type of this type, \"";
    if (NotDot(err.insert1))
    {
        Unicode::Cout(err.insert1);
        cout << "/";
    }
    Unicode::Cout(err.insert2);
    cout << "\", is immediately enclosed in type \"";
    if (NotDot(err.insert3))
    {
        Unicode::Cout(err.insert3);
        cout << "/";
    }
    Unicode::Cout(err.insert4);
    cout << "\" which does not match the type of this primary expression, \"";
    if (NotDot(err.insert5))
    {
        Unicode::Cout(err.insert5);
        cout << "/";
    }
    Unicode::Cout(err.insert6);
    cout << "\"";

    return;
}


void SemanticError::PrintPRIVATE_ENCLOSED_CONSTRUCTOR(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "Access to a private enclosed constructor \"";
    Unicode::Cout(err.insert1);
    cout << "\" is currently unsupported... Awaiting clarification of language spec";

    return;
}


void SemanticError::PrintCONSTRUCTOR_FOUND_IN_ANONYMOUS_CLASS(ErrorInfo &err, LexStream *lex_stream, Control &control)
{
    cout << "An anonymous class cannot have a constructor";

    return;
}