org.codehaus.groovy.grails.web.json.parser
Class TokenMgrError

java.lang.Object
  extended by java.lang.Throwable
      extended by java.lang.Error
          extended by org.codehaus.groovy.grails.web.json.parser.TokenMgrError
All Implemented Interfaces:
Serializable

public class TokenMgrError
extends Error

Token Manager Error.

See Also:
Serialized Form

Field Summary
(package private)  int errorCode
          Indicates the reason why the exception is thrown.
(package private) static int INVALID_LEXICAL_STATE
          Tried to change to an invalid lexical state.
(package private) static int LEXICAL_ERROR
          Lexical error occurred.
(package private) static int LOOP_DETECTED
          Detected (and bailed out of) an infinite loop in the token manager.
(package private) static int STATIC_LEXER_ERROR
          An attempt was made to create a second instance of a static token manager.
 
Constructor Summary
TokenMgrError()
          No arg constructor.
TokenMgrError(boolean EOFSeen, int lexState, int errorLine, int errorColumn, String errorAfter, char curChar, int reason)
          Full Constructor.
TokenMgrError(String message, int reason)
          Constructor with message and reason.
 
Method Summary
protected static String addEscapes(String str)
          Replaces unprintable characters by their escaped (or unicode escaped) equivalents in the given string
 String getMessage()
          You can also modify the body of this method to customize your error messages.
protected static String LexicalError(boolean EOFSeen, int lexState, int errorLine, int errorColumn, String errorAfter, char curChar)
          Returns a detailed message for the Error when it is thrown by the token manager to indicate a lexical error.
 
Methods inherited from class java.lang.Throwable
fillInStackTrace, getCause, getLocalizedMessage, getStackTrace, initCause, printStackTrace, printStackTrace, printStackTrace, setStackTrace, toString
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
 

Field Detail

LEXICAL_ERROR

static final int LEXICAL_ERROR
Lexical error occurred.

See Also:
Constant Field Values

STATIC_LEXER_ERROR

static final int STATIC_LEXER_ERROR
An attempt was made to create a second instance of a static token manager.

See Also:
Constant Field Values

INVALID_LEXICAL_STATE

static final int INVALID_LEXICAL_STATE
Tried to change to an invalid lexical state.

See Also:
Constant Field Values

LOOP_DETECTED

static final int LOOP_DETECTED
Detected (and bailed out of) an infinite loop in the token manager.

See Also:
Constant Field Values

errorCode

int errorCode
Indicates the reason why the exception is thrown. It will have one of the above 4 values.

Constructor Detail

TokenMgrError

public TokenMgrError()
No arg constructor.


TokenMgrError

public TokenMgrError(String message,
                     int reason)
Constructor with message and reason.


TokenMgrError

public TokenMgrError(boolean EOFSeen,
                     int lexState,
                     int errorLine,
                     int errorColumn,
                     String errorAfter,
                     char curChar,
                     int reason)
Full Constructor.

Method Detail

addEscapes

protected static final String addEscapes(String str)
Replaces unprintable characters by their escaped (or unicode escaped) equivalents in the given string


LexicalError

protected static String LexicalError(boolean EOFSeen,
                                     int lexState,
                                     int errorLine,
                                     int errorColumn,
                                     String errorAfter,
                                     char curChar)
Returns a detailed message for the Error when it is thrown by the token manager to indicate a lexical error. Parameters : EOFSeen : indicates if EOF caused the lexical error curLexState : lexical state in which this error occurred errorLine : line number when the error occurred errorColumn : column number when the error occurred errorAfter : prefix that was seen before this error occurred curchar : the offending character Note: You can customize the lexical error message by modifying this method.


getMessage

public String getMessage()
You can also modify the body of this method to customize your error messages. For example, cases like LOOP_DETECTED and INVALID_LEXICAL_STATE are not of end-users concern, so you can return something like :

"Internal Error : Please file a bug report .... "

from this method for such cases in the release version of your parser.

Overrides:
getMessage in class Throwable


Copyright (c) 2005-2009 The Grails project