diff options
Diffstat (limited to 'JavaScriptCore/runtime/LiteralParser.h')
-rw-r--r-- | JavaScriptCore/runtime/LiteralParser.h | 112 |
1 files changed, 112 insertions, 0 deletions
diff --git a/JavaScriptCore/runtime/LiteralParser.h b/JavaScriptCore/runtime/LiteralParser.h new file mode 100644 index 0000000..a72e3d0 --- /dev/null +++ b/JavaScriptCore/runtime/LiteralParser.h @@ -0,0 +1,112 @@ +/* + * Copyright (C) 2009 Apple Inc. All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY + * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR + * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR + * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, + * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, + * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR + * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY + * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +#ifndef LiteralParser_h +#define LiteralParser_h + +#include "JSGlobalObjectFunctions.h" +#include "JSValue.h" +#include "UString.h" + +namespace JSC { + + class LiteralParser { + public: + LiteralParser(ExecState* exec, const UString& s) + : m_exec(exec) + , m_lexer(s) + , m_depth(0) + , m_aborted(false) + { + } + + JSValue tryLiteralParse() + { + m_lexer.next(); + JSValue result = parseStatement(); + if (m_aborted || m_lexer.currentToken().type != TokEnd) + return JSValue(); + return result; + } + private: + + enum TokenType { TokLBracket, TokRBracket, TokLBrace, TokRBrace, + TokString, TokIdentifier, TokNumber, TokColon, + TokLParen, TokRParen, TokComma, TokEnd, TokError }; + + class Lexer { + public: + struct LiteralParserToken { + TokenType type; + const UChar* start; + const UChar* end; + }; + Lexer(const UString& s) + : m_string(s) + , m_ptr(s.data()) + , m_end(s.data() + s.size()) + { + } + + TokenType next() + { + return lex(m_currentToken); + } + + const LiteralParserToken& currentToken() + { + return m_currentToken; + } + + private: + TokenType lex(LiteralParserToken&); + TokenType lexString(LiteralParserToken&); + TokenType lexNumber(LiteralParserToken&); + LiteralParserToken m_currentToken; + UString m_string; + const UChar* m_ptr; + const UChar* m_end; + }; + + class StackGuard; + JSValue parseStatement(); + JSValue parseExpression(); + JSValue parseArray(); + JSValue parseObject(); + + JSValue abortParse() + { + m_aborted = true; + return JSValue(); + } + + ExecState* m_exec; + LiteralParser::Lexer m_lexer; + int m_depth; + bool m_aborted; + }; +} + +#endif |