OLD | NEW |
1 // Copyright 2010 the V8 project authors. All rights reserved. | 1 // Copyright 2010 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 99 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
110 | 110 |
111 | 111 |
112 // Typedef only introduced to avoid unreadable code. | 112 // Typedef only introduced to avoid unreadable code. |
113 // Please do appreciate the required space in "> >". | 113 // Please do appreciate the required space in "> >". |
114 typedef ZoneList<Handle<String> > ZoneStringList; | 114 typedef ZoneList<Handle<String> > ZoneStringList; |
115 typedef ZoneList<Handle<Object> > ZoneObjectList; | 115 typedef ZoneList<Handle<Object> > ZoneObjectList; |
116 | 116 |
117 | 117 |
118 class AstNode: public ZoneObject { | 118 class AstNode: public ZoneObject { |
119 public: | 119 public: |
| 120 static const int kNoNumber = -1; |
| 121 |
| 122 AstNode() : num_(kNoNumber) {} |
120 virtual ~AstNode() { } | 123 virtual ~AstNode() { } |
121 virtual void Accept(AstVisitor* v) = 0; | 124 virtual void Accept(AstVisitor* v) = 0; |
122 | 125 |
123 // Type testing & conversion. | 126 // Type testing & conversion. |
124 virtual Statement* AsStatement() { return NULL; } | 127 virtual Statement* AsStatement() { return NULL; } |
125 virtual ExpressionStatement* AsExpressionStatement() { return NULL; } | 128 virtual ExpressionStatement* AsExpressionStatement() { return NULL; } |
126 virtual EmptyStatement* AsEmptyStatement() { return NULL; } | 129 virtual EmptyStatement* AsEmptyStatement() { return NULL; } |
127 virtual Expression* AsExpression() { return NULL; } | 130 virtual Expression* AsExpression() { return NULL; } |
128 virtual Literal* AsLiteral() { return NULL; } | 131 virtual Literal* AsLiteral() { return NULL; } |
129 virtual Slot* AsSlot() { return NULL; } | 132 virtual Slot* AsSlot() { return NULL; } |
130 virtual VariableProxy* AsVariableProxy() { return NULL; } | 133 virtual VariableProxy* AsVariableProxy() { return NULL; } |
131 virtual Property* AsProperty() { return NULL; } | 134 virtual Property* AsProperty() { return NULL; } |
132 virtual Call* AsCall() { return NULL; } | 135 virtual Call* AsCall() { return NULL; } |
133 virtual TargetCollector* AsTargetCollector() { return NULL; } | 136 virtual TargetCollector* AsTargetCollector() { return NULL; } |
134 virtual BreakableStatement* AsBreakableStatement() { return NULL; } | 137 virtual BreakableStatement* AsBreakableStatement() { return NULL; } |
135 virtual IterationStatement* AsIterationStatement() { return NULL; } | 138 virtual IterationStatement* AsIterationStatement() { return NULL; } |
136 virtual UnaryOperation* AsUnaryOperation() { return NULL; } | 139 virtual UnaryOperation* AsUnaryOperation() { return NULL; } |
137 virtual BinaryOperation* AsBinaryOperation() { return NULL; } | 140 virtual BinaryOperation* AsBinaryOperation() { return NULL; } |
138 virtual Assignment* AsAssignment() { return NULL; } | 141 virtual Assignment* AsAssignment() { return NULL; } |
139 virtual FunctionLiteral* AsFunctionLiteral() { return NULL; } | 142 virtual FunctionLiteral* AsFunctionLiteral() { return NULL; } |
140 virtual MaterializedLiteral* AsMaterializedLiteral() { return NULL; } | 143 virtual MaterializedLiteral* AsMaterializedLiteral() { return NULL; } |
141 virtual ObjectLiteral* AsObjectLiteral() { return NULL; } | 144 virtual ObjectLiteral* AsObjectLiteral() { return NULL; } |
142 virtual ArrayLiteral* AsArrayLiteral() { return NULL; } | 145 virtual ArrayLiteral* AsArrayLiteral() { return NULL; } |
143 virtual CompareOperation* AsCompareOperation() { return NULL; } | 146 virtual CompareOperation* AsCompareOperation() { return NULL; } |
| 147 |
| 148 int num() { return num_; } |
| 149 void set_num(int n) { num_ = n; } |
| 150 |
| 151 private: |
| 152 // Support for ast node numbering. |
| 153 int num_; |
144 }; | 154 }; |
145 | 155 |
146 | 156 |
147 class Statement: public AstNode { | 157 class Statement: public AstNode { |
148 public: | 158 public: |
149 Statement() : statement_pos_(RelocInfo::kNoPosition) {} | 159 Statement() : statement_pos_(RelocInfo::kNoPosition) {} |
150 | 160 |
151 virtual Statement* AsStatement() { return this; } | 161 virtual Statement* AsStatement() { return this; } |
152 virtual ReturnStatement* AsReturnStatement() { return NULL; } | 162 virtual ReturnStatement* AsReturnStatement() { return NULL; } |
153 | 163 |
(...skipping 20 matching lines...) Expand all Loading... |
174 // Evaluated for control flow (and side effects). | 184 // Evaluated for control flow (and side effects). |
175 kTest, | 185 kTest, |
176 // Evaluated for control flow and side effects. Value is also | 186 // Evaluated for control flow and side effects. Value is also |
177 // needed if true. | 187 // needed if true. |
178 kValueTest, | 188 kValueTest, |
179 // Evaluated for control flow and side effects. Value is also | 189 // Evaluated for control flow and side effects. Value is also |
180 // needed if false. | 190 // needed if false. |
181 kTestValue | 191 kTestValue |
182 }; | 192 }; |
183 | 193 |
184 static const int kNoLabel = -1; | |
185 | |
186 Expression() | 194 Expression() |
187 : bitfields_(0), | 195 : bitfields_(0), |
188 num_(kNoLabel), | |
189 def_(NULL), | 196 def_(NULL), |
190 defined_vars_(NULL) {} | 197 defined_vars_(NULL) {} |
191 | 198 |
192 virtual Expression* AsExpression() { return this; } | 199 virtual Expression* AsExpression() { return this; } |
193 | 200 |
194 virtual bool IsValidLeftHandSide() { return false; } | 201 virtual bool IsValidLeftHandSide() { return false; } |
195 | 202 |
196 // Symbols that cannot be parsed as array indices are considered property | 203 // Symbols that cannot be parsed as array indices are considered property |
197 // names. We do not treat symbols that can be array indexes as property | 204 // names. We do not treat symbols that can be array indexes as property |
198 // names because [] for string objects is handled only by keyed ICs. | 205 // names because [] for string objects is handled only by keyed ICs. |
199 virtual bool IsPropertyName() { return false; } | 206 virtual bool IsPropertyName() { return false; } |
200 | 207 |
201 // True if the expression does not have (evaluated) subexpressions. | 208 // True if the expression does not have (evaluated) subexpressions. |
202 // Function literals are leaves because their subexpressions are not | 209 // Function literals are leaves because their subexpressions are not |
203 // evaluated. | 210 // evaluated. |
204 virtual bool IsLeaf() { return false; } | 211 virtual bool IsLeaf() { return false; } |
205 | 212 |
206 // True if the expression has no side effects and is safe to | 213 // True if the expression has no side effects and is safe to |
207 // evaluate out of order. | 214 // evaluate out of order. |
208 virtual bool IsTrivial() { return false; } | 215 virtual bool IsTrivial() { return false; } |
209 | 216 |
210 // Mark the expression as being compiled as an expression | 217 // Mark the expression as being compiled as an expression |
211 // statement. This is used to transform postfix increments to | 218 // statement. This is used to transform postfix increments to |
212 // (faster) prefix increments. | 219 // (faster) prefix increments. |
213 virtual void MarkAsStatement() { /* do nothing */ } | 220 virtual void MarkAsStatement() { /* do nothing */ } |
214 | 221 |
215 // Static type information for this expression. | 222 // Static type information for this expression. |
216 StaticType* type() { return &type_; } | 223 StaticType* type() { return &type_; } |
217 | 224 |
218 int num() { return num_; } | |
219 | |
220 // AST node numbering ordered by evaluation order. | |
221 void set_num(int n) { num_ = n; } | |
222 | |
223 // Data flow information. | 225 // Data flow information. |
224 DefinitionInfo* var_def() { return def_; } | 226 DefinitionInfo* var_def() { return def_; } |
225 void set_var_def(DefinitionInfo* def) { def_ = def; } | 227 void set_var_def(DefinitionInfo* def) { def_ = def; } |
226 | 228 |
227 ZoneList<DefinitionInfo*>* defined_vars() { return defined_vars_; } | 229 ZoneList<DefinitionInfo*>* defined_vars() { return defined_vars_; } |
228 void set_defined_vars(ZoneList<DefinitionInfo*>* defined_vars) { | 230 void set_defined_vars(ZoneList<DefinitionInfo*>* defined_vars) { |
229 defined_vars_ = defined_vars; | 231 defined_vars_ = defined_vars; |
230 } | 232 } |
231 | 233 |
232 // AST analysis results | 234 // AST analysis results |
(...skipping 21 matching lines...) Expand all Loading... |
254 void set_stack_height(int stack_height) { | 256 void set_stack_height(int stack_height) { |
255 bitfields_ &= ~StackHeightField::mask(); | 257 bitfields_ &= ~StackHeightField::mask(); |
256 bitfields_ |= | 258 bitfields_ |= |
257 StackHeightField::encode(Min(stack_height, StackHeightMax)); | 259 StackHeightField::encode(Min(stack_height, StackHeightMax)); |
258 } | 260 } |
259 | 261 |
260 private: | 262 private: |
261 uint32_t bitfields_; | 263 uint32_t bitfields_; |
262 StaticType type_; | 264 StaticType type_; |
263 | 265 |
264 int num_; | |
265 DefinitionInfo* def_; | 266 DefinitionInfo* def_; |
266 ZoneList<DefinitionInfo*>* defined_vars_; | 267 ZoneList<DefinitionInfo*>* defined_vars_; |
267 | 268 |
268 static const int SideEffectFreeFieldStart = 0; | 269 static const int SideEffectFreeFieldStart = 0; |
269 static const int SideEffectFreeFieldLength = 1; | 270 static const int SideEffectFreeFieldLength = 1; |
270 class SideEffectFreeField: public BitField<bool, | 271 class SideEffectFreeField: public BitField<bool, |
271 SideEffectFreeFieldStart, | 272 SideEffectFreeFieldStart, |
272 SideEffectFreeFieldLength> { | 273 SideEffectFreeFieldLength> { |
273 }; | 274 }; |
274 | 275 |
(...skipping 1633 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1908 #undef DEF_VISIT | 1909 #undef DEF_VISIT |
1909 | 1910 |
1910 private: | 1911 private: |
1911 bool stack_overflow_; | 1912 bool stack_overflow_; |
1912 }; | 1913 }; |
1913 | 1914 |
1914 | 1915 |
1915 } } // namespace v8::internal | 1916 } } // namespace v8::internal |
1916 | 1917 |
1917 #endif // V8_AST_H_ | 1918 #endif // V8_AST_H_ |
OLD | NEW |