2 * Copyright (C) 2010 Apple Inc. All rights reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
7 * 1. Redistributions of source code must retain the above copyright
8 * notice, this list of conditions and the following disclaimer.
9 * 2. Redistributions in binary form must reproduce the above copyright
10 * notice, this list of conditions and the following disclaimer in the
11 * documentation and/or other materials provided with the distribution.
13 * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
14 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
15 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
17 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
18 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
19 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
20 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
21 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
22 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
23 * THE POSSIBILITY OF SUCH DAMAGE.
26 #ifndef SyntaxChecker_h
27 #define SyntaxChecker_h
30 #include <yarr/YarrSyntaxChecker.h>
35 struct BinaryExprContext
{
36 BinaryExprContext(SyntaxChecker
& context
)
39 m_context
->m_topBinaryExprs
.append(m_context
->m_topBinaryExpr
);
40 m_context
->m_topBinaryExpr
= 0;
44 m_context
->m_topBinaryExpr
= m_context
->m_topBinaryExprs
.last();
45 m_context
->m_topBinaryExprs
.removeLast();
48 SyntaxChecker
* m_context
;
50 struct UnaryExprContext
{
51 UnaryExprContext(SyntaxChecker
& context
)
54 m_context
->m_topUnaryTokens
.append(m_context
->m_topUnaryToken
);
55 m_context
->m_topUnaryToken
= 0;
59 m_context
->m_topUnaryToken
= m_context
->m_topUnaryTokens
.last();
60 m_context
->m_topUnaryTokens
.removeLast();
63 SyntaxChecker
* m_context
;
66 SyntaxChecker(JSGlobalData
* , Lexer
*)
70 typedef SyntaxChecker FunctionBodyBuilder
;
72 ResolveEvalExpr
, ResolveExpr
, NumberExpr
, StringExpr
,
73 ThisExpr
, NullExpr
, BoolExpr
, RegExpExpr
, ObjectLiteralExpr
,
74 FunctionExpr
, BracketExpr
, DotExpr
, CallExpr
,
75 NewExpr
, PreExpr
, PostExpr
, UnaryExpr
, BinaryExpr
,
76 ConditionalExpr
, AssignmentExpr
, TypeofExpr
,
77 DeleteExpr
, ArrayLiteralExpr
};
78 typedef int ExpressionType
;
80 typedef ExpressionType Expression
;
81 typedef int SourceElements
;
82 typedef int Arguments
;
83 typedef ExpressionType Comma
;
85 ALWAYS_INLINE
Property(void* = 0)
86 : type((PropertyNode::Type
)0)
89 ALWAYS_INLINE
Property(const Identifier
* ident
, PropertyNode::Type ty
)
94 ALWAYS_INLINE
Property(PropertyNode::Type ty
)
99 ALWAYS_INLINE
bool operator!() { return !type
; }
100 const Identifier
* name
;
101 PropertyNode::Type type
;
103 typedef int PropertyList
;
104 typedef int ElementList
;
105 typedef int ArgumentsList
;
106 typedef int FormalParameterList
;
107 typedef int FunctionBody
;
108 typedef int Statement
;
109 typedef int ClauseList
;
111 typedef int ConstDeclList
;
112 typedef int BinaryOperand
;
114 static const bool CreatesAST
= false;
115 static const bool NeedsFreeVariableInfo
= false;
116 static const bool CanUseFunctionCache
= true;
117 static const unsigned DontBuildKeywords
= Lexer::DontBuildKeywords
;
118 static const unsigned DontBuildStrings
= Lexer::DontBuildStrings
;
120 int createSourceElements() { return 1; }
121 ExpressionType
makeFunctionCallNode(int, int, int, int, int) { return CallExpr
; }
122 void appendToComma(ExpressionType
& base
, ExpressionType right
) { base
= right
; }
123 ExpressionType
createCommaExpr(ExpressionType
, ExpressionType right
) { return right
; }
124 ExpressionType
makeAssignNode(ExpressionType
, Operator
, ExpressionType
, bool, bool, int, int, int) { return AssignmentExpr
; }
125 ExpressionType
makePrefixNode(ExpressionType
, Operator
, int, int, int) { return PreExpr
; }
126 ExpressionType
makePostfixNode(ExpressionType
, Operator
, int, int, int) { return PostExpr
; }
127 ExpressionType
makeTypeOfNode(ExpressionType
) { return TypeofExpr
; }
128 ExpressionType
makeDeleteNode(ExpressionType
, int, int, int) { return DeleteExpr
; }
129 ExpressionType
makeNegateNode(ExpressionType
) { return UnaryExpr
; }
130 ExpressionType
makeBitwiseNotNode(ExpressionType
) { return UnaryExpr
; }
131 ExpressionType
createLogicalNot(ExpressionType
) { return UnaryExpr
; }
132 ExpressionType
createUnaryPlus(ExpressionType
) { return UnaryExpr
; }
133 ExpressionType
createVoid(ExpressionType
) { return UnaryExpr
; }
134 ExpressionType
thisExpr() { return ThisExpr
; }
135 ExpressionType
createResolve(const Identifier
*, int) { return ResolveExpr
; }
136 ExpressionType
createObjectLiteral() { return ObjectLiteralExpr
; }
137 ExpressionType
createObjectLiteral(int) { return ObjectLiteralExpr
; }
138 ExpressionType
createArray(int) { return ArrayLiteralExpr
; }
139 ExpressionType
createArray(int, int) { return ArrayLiteralExpr
; }
140 ExpressionType
createNumberExpr(double) { return NumberExpr
; }
141 ExpressionType
createString(const Identifier
*) { return StringExpr
; }
142 ExpressionType
createBoolean(bool) { return BoolExpr
; }
143 ExpressionType
createNull() { return NullExpr
; }
144 ExpressionType
createBracketAccess(ExpressionType
, ExpressionType
, bool, int, int, int) { return BracketExpr
; }
145 ExpressionType
createDotAccess(ExpressionType
, const Identifier
*, int, int, int) { return DotExpr
; }
146 ExpressionType
createRegExp(const Identifier
& pattern
, const Identifier
&, int) { return Yarr::checkSyntax(pattern
.ustring()) ? 0 : RegExpExpr
; }
147 ExpressionType
createNewExpr(ExpressionType
, int, int, int, int) { return NewExpr
; }
148 ExpressionType
createNewExpr(ExpressionType
, int, int) { return NewExpr
; }
149 ExpressionType
createConditionalExpr(ExpressionType
, ExpressionType
, ExpressionType
) { return ConditionalExpr
; }
150 ExpressionType
createAssignResolve(const Identifier
&, ExpressionType
, bool, int, int, int) { return AssignmentExpr
; }
151 ExpressionType
createFunctionExpr(const Identifier
*, int, int, int, int, int, int) { return FunctionExpr
; }
152 int createFunctionBody(bool) { return 1; }
153 int createArguments() { return 1; }
154 int createArguments(int) { return 1; }
155 int createArgumentsList(int) { return 1; }
156 int createArgumentsList(int, int) { return 1; }
157 template <bool complete
> Property
createProperty(const Identifier
* name
, int, PropertyNode::Type type
)
160 return Property(type
);
162 return Property(name
, type
);
164 template <bool complete
> Property
createProperty(JSGlobalData
* globalData
, double name
, int, PropertyNode::Type type
)
167 return Property(type
);
168 return Property(&globalData
->parser
->arena().identifierArena().makeNumericIdentifier(globalData
, name
), type
);
170 int createPropertyList(Property
) { return 1; }
171 int createPropertyList(Property
, int) { return 1; }
172 int createElementList(int, int) { return 1; }
173 int createElementList(int, int, int) { return 1; }
174 int createFormalParameterList(const Identifier
&) { return 1; }
175 int createFormalParameterList(int, const Identifier
&) { return 1; }
176 int createClause(int, int) { return 1; }
177 int createClauseList(int) { return 1; }
178 int createClauseList(int, int) { return 1; }
179 void setUsesArguments(int) { }
180 int createFuncDeclStatement(const Identifier
*, int, int, int, int, int, int) { return 1; }
181 int createBlockStatement(int, int, int) { return 1; }
182 int createExprStatement(int, int, int) { return 1; }
183 int createIfStatement(int, int, int, int) { return 1; }
184 int createIfStatement(int, int, int, int, int) { return 1; }
185 int createForLoop(int, int, int, int, bool, int, int) { return 1; }
186 int createForInLoop(const Identifier
*, int, int, int, int, int, int, int, int, int, int) { return 1; }
187 int createForInLoop(int, int, int, int, int, int, int, int) { return 1; }
188 int createEmptyStatement() { return 1; }
189 int createVarStatement(int, int, int) { return 1; }
190 int createReturnStatement(int, int, int, int, int) { return 1; }
191 int createBreakStatement(int, int, int, int) { return 1; }
192 int createBreakStatement(const Identifier
*, int, int, int, int) { return 1; }
193 int createContinueStatement(int, int, int, int) { return 1; }
194 int createContinueStatement(const Identifier
*, int, int, int, int) { return 1; }
195 int createTryStatement(int, const Identifier
*, bool, int, int, int, int) { return 1; }
196 int createSwitchStatement(int, int, int, int, int, int) { return 1; }
197 int createWhileStatement(int, int, int, int) { return 1; }
198 int createWithStatement(int, int, int, int, int, int) { return 1; }
199 int createDoWhileStatement(int, int, int, int) { return 1; }
200 int createLabelStatement(const Identifier
*, int, int, int) { return 1; }
201 int createThrowStatement(int, int, int, int, int) { return 1; }
202 int createDebugger(int, int) { return 1; }
203 int createConstStatement(int, int, int) { return 1; }
204 int appendConstDecl(int, const Identifier
*, int) { return 1; }
205 template <bool strict
> Property
createGetterOrSetterProperty(PropertyNode::Type type
, const Identifier
* name
, int, int, int, int, int, int)
209 return Property(type
);
210 return Property(name
, type
);
213 void appendStatement(int, int) { }
214 void addVar(const Identifier
*, bool) { }
215 int combineCommaNodes(int, int) { return 1; }
216 int evalCount() const { return 0; }
217 void appendBinaryExpressionInfo(int& operandStackDepth
, int expr
, int, int, int, bool)
219 if (!m_topBinaryExpr
)
220 m_topBinaryExpr
= expr
;
222 m_topBinaryExpr
= BinaryExpr
;
226 // Logic to handle datastructures used during parsing of binary expressions
227 void operatorStackPop(int& operatorStackDepth
) { operatorStackDepth
--; }
228 bool operatorStackHasHigherPrecedence(int&, int) { return true; }
229 BinaryOperand
getFromOperandStack(int) { return m_topBinaryExpr
; }
230 void shrinkOperandStackBy(int& operandStackDepth
, int amount
) { operandStackDepth
-= amount
; }
231 void appendBinaryOperation(int& operandStackDepth
, int&, BinaryOperand
, BinaryOperand
) { operandStackDepth
++; }
232 void operatorStackAppend(int& operatorStackDepth
, int, int) { operatorStackDepth
++; }
233 int popOperandStack(int&) { int res
= m_topBinaryExpr
; m_topBinaryExpr
= 0; return res
; }
235 void appendUnaryToken(int& stackDepth
, int tok
, int) { stackDepth
= 1; m_topUnaryToken
= tok
; }
236 int unaryTokenStackLastType(int&) { return m_topUnaryToken
; }
237 int unaryTokenStackLastStart(int&) { return 0; }
238 void unaryTokenStackRemoveLast(int& stackDepth
) { stackDepth
= 0; }
240 void assignmentStackAppend(int, int, int, int, int, Operator
) { }
241 int createAssignment(int, int, int, int, int) { ASSERT_NOT_REACHED(); return 1; }
242 const Identifier
& getName(const Property
& property
) const { ASSERT(property
.name
); return *property
.name
; }
243 PropertyNode::Type
getType(const Property
& property
) const { return property
.type
; }
244 bool isResolve(ExpressionType expr
) const { return expr
== ResolveExpr
|| expr
== ResolveEvalExpr
; }
249 Vector
<int, 8> m_topBinaryExprs
;
250 Vector
<int, 8> m_topUnaryTokens
;