#ifndef ParserError_h
#define ParserError_h
#include "Error.h"
#include "ExceptionHelpers.h"
#include "ParserTokens.h"
#include <wtf/text/WTFString.h>
namespace JSC {
struct ParserError {
enum SyntaxErrorType {
SyntaxErrorNone,
SyntaxErrorIrrecoverable,
SyntaxErrorUnterminatedLiteral,
SyntaxErrorRecoverable
};
enum ErrorType {
ErrorNone,
StackOverflow,
EvalError,
OutOfMemory,
SyntaxError
};
ErrorType m_type;
SyntaxErrorType m_syntaxErrorType;
JSToken m_token;
String m_message;
int m_line;
ParserError()
: m_type(ErrorNone)
, m_syntaxErrorType(SyntaxErrorNone)
, m_line(-1)
{
}
explicit ParserError(ErrorType type)
: m_type(type)
, m_syntaxErrorType(SyntaxErrorNone)
, m_line(-1)
{
}
ParserError(ErrorType type, SyntaxErrorType syntaxError, JSToken token)
: m_type(type)
, m_syntaxErrorType(syntaxError)
, m_token(token)
, m_line(-1)
{
}
ParserError(ErrorType type, SyntaxErrorType syntaxError, JSToken token, String msg, int line)
: m_type(type)
, m_syntaxErrorType(syntaxError)
, m_token(token)
, m_message(msg)
, m_line(line)
{
}
JSObject* toErrorObject(JSGlobalObject* globalObject, const SourceCode& source)
{
switch (m_type) {
case ErrorNone:
return 0;
case SyntaxError:
return addErrorInfo(globalObject->globalExec(), createSyntaxError(globalObject, m_message), m_line, source);
case EvalError:
return createSyntaxError(globalObject, m_message);
case StackOverflow:
return createStackOverflowError(globalObject);
case OutOfMemory:
return createOutOfMemoryError(globalObject);
}
CRASH();
return createOutOfMemoryError(globalObject); }
#undef GET_ERROR_CODE
};
}
#endif // ParserError_h