Blame vhdlparser/TokenMgrError.cc

Packit 1c1d7e
/* Generated By:JavaCC: Do not edit this line. TokenMgrError.cc Version 6.0 */
Packit 1c1d7e
/* JavaCCOptions:STATIC=false,SUPPORT_CLASS_VISIBILITY_PUBLIC=true */
Packit 1c1d7e
#include "TokenMgrError.h"
Packit 1c1d7e
Packit 1c1d7e
namespace vhdl {
Packit 1c1d7e
namespace parser {
Packit 1c1d7e
Packit 1c1d7e
  /**
Packit 1c1d7e
   * Returns a detailed message for the Error when it is thrown by the
Packit 1c1d7e
   * token manager to indicate a lexical error.
Packit 1c1d7e
   * Parameters :
Packit 1c1d7e
   *    EOFSeen     : indicates if EOF caused the lexical error
Packit 1c1d7e
   *    curLexState : lexical state in which this error occurred
Packit 1c1d7e
   *    errorLine   : line number when the error occurred
Packit 1c1d7e
   *    errorColumn : column number when the error occurred
Packit 1c1d7e
   *    errorAfter  : prefix that was seen before this error occurred
Packit 1c1d7e
   *    curJAVACC_CHAR_TYPE     : the offending character
Packit 1c1d7e
   * Note: You can customize the lexical error message by modifying this method.
Packit 1c1d7e
   */
Packit 1c1d7e
    JAVACC_STRING_TYPE TokenMgrError::LexicalError(bool EOFSeen, int lexState, int errorLine, int errorColumn, JAVACC_STRING_TYPE errorAfter, JAVACC_CHAR_TYPE curChar) {
Packit 1c1d7e
#if 0
Packit 1c1d7e
    JAVACC_STRING_TYPE s;
Packit 1c1d7e
    stringstream<JAVACC_STRING_TYPE> ss;
Packit 1c1d7e
    ss << "Lexical error at line " << errorLine << " column " << errorColumn
Packit 1c1d7e
       << ".  Encountered: " << curChar << "(" << (int)curChar
Packit 1c1d7e
       << ") after : \"" << errorAfter.c_str() << "\"";
Packit 1c1d7e
    return (JAVACC_STRING_TYPE)ss.rdbuf()->str();
Packit 1c1d7e
#endif
Packit 1c1d7e
    return EMPTY;
Packit 1c1d7e
  }
Packit 1c1d7e
Packit 1c1d7e
  /**
Packit 1c1d7e
   * You can also modify the body of this method to customize your error messages.
Packit 1c1d7e
   * For example, cases like LOOP_DETECTED and INVALID_LEXICAL_STATE are not
Packit 1c1d7e
   * of end-users concern, so you can return something like :
Packit 1c1d7e
   *
Packit 1c1d7e
   *     "Internal Error : Please file a bug report .... "
Packit 1c1d7e
   *
Packit 1c1d7e
   * from this method for such cases in the release version of your parser.
Packit 1c1d7e
   */
Packit 1c1d7e
  JAVACC_STRING_TYPE TokenMgrError::getMessage() {
Packit 1c1d7e
    return message;
Packit 1c1d7e
  }
Packit 1c1d7e
Packit 1c1d7e
  /*
Packit 1c1d7e
   * Constructors of various flavors follow.
Packit 1c1d7e
   */
Packit 1c1d7e
Packit 1c1d7e
  /** No arg constructor. */
Packit 1c1d7e
  TokenMgrError::TokenMgrError() {
Packit 1c1d7e
  }
Packit 1c1d7e
Packit 1c1d7e
  /** Constructor with message and reason. */
Packit 1c1d7e
  TokenMgrError::TokenMgrError(JAVACC_STRING_TYPE message, int reason) {
Packit 1c1d7e
    errorCode = reason;
Packit 1c1d7e
  }
Packit 1c1d7e
Packit 1c1d7e
  /** Full Constructor. */
Packit 1c1d7e
  TokenMgrError::TokenMgrError(bool EOFSeen, int lexState, int errorLine, int errorColumn, JAVACC_STRING_TYPE errorAfter, JAVACC_CHAR_TYPE curChar, int reason) {
Packit 1c1d7e
    message = LexicalError(EOFSeen, lexState, errorLine, errorColumn, errorAfter, curChar);
Packit 1c1d7e
   errorCode = reason;
Packit 1c1d7e
  }
Packit 1c1d7e
Packit 1c1d7e
// i < 16 - guaranteed
Packit 1c1d7e
char hexChar(int i) {
Packit 1c1d7e
  if (i < 10) {
Packit 1c1d7e
    return i - '0';
Packit 1c1d7e
  }
Packit 1c1d7e
  return 'a' + (i - 10);
Packit 1c1d7e
}
Packit 1c1d7e
Packit 1c1d7e
/**
Packit 1c1d7e
 * Replaces unprintable characters by their escaped (or unicode escaped)
Packit 1c1d7e
 * equivalents in the given string
Packit 1c1d7e
 */
Packit 1c1d7e
JAVACC_SIMPLE_STRING addUnicodeEscapes(JAVACC_STRING_TYPE str) {
Packit 1c1d7e
  JAVACC_SIMPLE_STRING retval;
Packit 1c1d7e
  for (size_t i = 0; i < str.size(); i++) {
Packit 1c1d7e
    JAVACC_CHAR_TYPE ch = str[i];
Packit 1c1d7e
    switch (ch)
Packit 1c1d7e
    {
Packit 1c1d7e
      case 0 :
Packit 1c1d7e
        retval += EMPTY[0];
Packit 1c1d7e
        continue;
Packit 1c1d7e
      case '\b':
Packit 1c1d7e
        retval.append("\\b");
Packit 1c1d7e
        continue;
Packit 1c1d7e
      case '\t':
Packit 1c1d7e
        retval.append("\\t");
Packit 1c1d7e
        continue;
Packit 1c1d7e
      case '\n':
Packit 1c1d7e
        retval.append("\\n");
Packit 1c1d7e
        continue;
Packit 1c1d7e
      case '\f':
Packit 1c1d7e
        retval.append("\\f");
Packit 1c1d7e
        continue;
Packit 1c1d7e
      case '\r':
Packit 1c1d7e
        retval.append("\\r");
Packit 1c1d7e
        continue;
Packit 1c1d7e
      case '\\':
Packit 1c1d7e
        retval.append("\\\\");
Packit 1c1d7e
        continue;
Packit 1c1d7e
      default:
Packit 1c1d7e
        if (ch < 0xff) {
Packit 1c1d7e
          retval += ch;
Packit 1c1d7e
          continue;
Packit 1c1d7e
        }
Packit 1c1d7e
        retval.append("\\u");
Packit 1c1d7e
        retval += (hexChar(ch >> 12));
Packit 1c1d7e
        retval += (hexChar((ch & 0x0f00) >> 8));
Packit 1c1d7e
        retval += (hexChar((ch & 0x00f0) >> 4));
Packit 1c1d7e
        retval += (hexChar(ch & 0x000f));
Packit 1c1d7e
        continue;
Packit 1c1d7e
    }
Packit 1c1d7e
  }
Packit 1c1d7e
  return retval;
Packit 1c1d7e
}
Packit 1c1d7e
Packit 1c1d7e
}
Packit 1c1d7e
}
Packit 1c1d7e
/* JavaCC - OriginalChecksum=2bf63f131c8e60fd30c70d0b4f660016 (do not edit this line) */