OLD | NEW |
(Empty) | |
| 1 // Copyright 2015 the V8 project authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. |
| 4 |
| 5 #include "src/ast/ast.h" |
| 6 #include "src/ast/ast-expression-rewriter.h" |
| 7 |
| 8 namespace v8 { |
| 9 namespace internal { |
| 10 |
| 11 // ---------------------------------------------------------------------------- |
| 12 // Implementation of AstExpressionRewriter |
| 13 // The AST is traversed but no actual rewriting takes place, unless the |
| 14 // Visit methods are overriden in subclasses. |
| 15 |
| 16 #define REWRITE_THIS(node) \ |
| 17 do { \ |
| 18 if (!RewriteExpression(node)) return; \ |
| 19 } while (false) |
| 20 #define NOTHING() DCHECK_NULL(replacement_) |
| 21 |
| 22 |
| 23 void AstExpressionRewriter::VisitDeclarations( |
| 24 ZoneList<Declaration*>* declarations) { |
| 25 for (int i = 0; i < declarations->length(); i++) { |
| 26 AST_REWRITE(Declaration, declarations->at(i), |
| 27 declarations->Set(i, replacement)); |
| 28 } |
| 29 } |
| 30 |
| 31 |
| 32 void AstExpressionRewriter::VisitStatements(ZoneList<Statement*>* statements) { |
| 33 for (int i = 0; i < statements->length(); i++) { |
| 34 AST_REWRITE(Statement, statements->at(i), statements->Set(i, replacement)); |
| 35 // Not stopping when a jump statement is found. |
| 36 } |
| 37 } |
| 38 |
| 39 |
| 40 void AstExpressionRewriter::VisitExpressions( |
| 41 ZoneList<Expression*>* expressions) { |
| 42 for (int i = 0; i < expressions->length(); i++) { |
| 43 // The variable statement visiting code may pass NULL expressions |
| 44 // to this code. Maybe this should be handled by introducing an |
| 45 // undefined expression or literal? Revisit this code if this |
| 46 // changes |
| 47 Expression* expression = expressions->at(i); |
| 48 if (expression != nullptr) { |
| 49 AST_REWRITE(Expression, expression, expressions->Set(i, replacement)); |
| 50 } |
| 51 } |
| 52 } |
| 53 |
| 54 |
| 55 void AstExpressionRewriter::VisitVariableDeclaration( |
| 56 VariableDeclaration* node) { |
| 57 // Not visiting `proxy_`. |
| 58 NOTHING(); |
| 59 } |
| 60 |
| 61 |
| 62 void AstExpressionRewriter::VisitFunctionDeclaration( |
| 63 FunctionDeclaration* node) { |
| 64 // Not visiting `proxy_`. |
| 65 AST_REWRITE(FunctionLiteral, node->fun(), node->set_fun(replacement)); |
| 66 } |
| 67 |
| 68 |
| 69 void AstExpressionRewriter::VisitImportDeclaration(ImportDeclaration* node) { |
| 70 // Not visiting `proxy_`. |
| 71 NOTHING(); |
| 72 } |
| 73 |
| 74 |
| 75 void AstExpressionRewriter::VisitExportDeclaration(ExportDeclaration* node) { |
| 76 // Not visiting `proxy_`. |
| 77 NOTHING(); |
| 78 } |
| 79 |
| 80 |
| 81 void AstExpressionRewriter::VisitBlock(Block* node) { |
| 82 VisitStatements(node->statements()); |
| 83 } |
| 84 |
| 85 |
| 86 void AstExpressionRewriter::VisitExpressionStatement( |
| 87 ExpressionStatement* node) { |
| 88 AST_REWRITE(Expression, node->expression(), |
| 89 node->set_expression(replacement)); |
| 90 } |
| 91 |
| 92 |
| 93 void AstExpressionRewriter::VisitEmptyStatement(EmptyStatement* node) { |
| 94 NOTHING(); |
| 95 } |
| 96 |
| 97 |
| 98 void AstExpressionRewriter::VisitSloppyBlockFunctionStatement( |
| 99 SloppyBlockFunctionStatement* node) { |
| 100 AST_REWRITE(Statement, node->statement(), node->set_statement(replacement)); |
| 101 } |
| 102 |
| 103 |
| 104 void AstExpressionRewriter::VisitIfStatement(IfStatement* node) { |
| 105 AST_REWRITE(Expression, node->condition(), node->set_condition(replacement)); |
| 106 AST_REWRITE(Statement, node->then_statement(), |
| 107 node->set_then_statement(replacement)); |
| 108 AST_REWRITE(Statement, node->else_statement(), |
| 109 node->set_else_statement(replacement)); |
| 110 } |
| 111 |
| 112 |
| 113 void AstExpressionRewriter::VisitContinueStatement(ContinueStatement* node) { |
| 114 NOTHING(); |
| 115 } |
| 116 |
| 117 |
| 118 void AstExpressionRewriter::VisitBreakStatement(BreakStatement* node) { |
| 119 NOTHING(); |
| 120 } |
| 121 |
| 122 |
| 123 void AstExpressionRewriter::VisitReturnStatement(ReturnStatement* node) { |
| 124 AST_REWRITE(Expression, node->expression(), |
| 125 node->set_expression(replacement)); |
| 126 } |
| 127 |
| 128 |
| 129 void AstExpressionRewriter::VisitWithStatement(WithStatement* node) { |
| 130 AST_REWRITE(Expression, node->expression(), |
| 131 node->set_expression(replacement)); |
| 132 AST_REWRITE(Statement, node->statement(), node->set_statement(replacement)); |
| 133 } |
| 134 |
| 135 |
| 136 void AstExpressionRewriter::VisitSwitchStatement(SwitchStatement* node) { |
| 137 AST_REWRITE(Expression, node->tag(), node->set_tag(replacement)); |
| 138 ZoneList<CaseClause*>* clauses = node->cases(); |
| 139 for (int i = 0; i < clauses->length(); i++) { |
| 140 AST_REWRITE(CaseClause, clauses->at(i), clauses->Set(i, replacement)); |
| 141 } |
| 142 } |
| 143 |
| 144 |
| 145 void AstExpressionRewriter::VisitDoWhileStatement(DoWhileStatement* node) { |
| 146 AST_REWRITE(Expression, node->cond(), node->set_cond(replacement)); |
| 147 AST_REWRITE(Statement, node->body(), node->set_body(replacement)); |
| 148 } |
| 149 |
| 150 |
| 151 void AstExpressionRewriter::VisitWhileStatement(WhileStatement* node) { |
| 152 AST_REWRITE(Expression, node->cond(), node->set_cond(replacement)); |
| 153 AST_REWRITE(Statement, node->body(), node->set_body(replacement)); |
| 154 } |
| 155 |
| 156 |
| 157 void AstExpressionRewriter::VisitForStatement(ForStatement* node) { |
| 158 if (node->init() != nullptr) { |
| 159 AST_REWRITE(Statement, node->init(), node->set_init(replacement)); |
| 160 } |
| 161 if (node->cond() != nullptr) { |
| 162 AST_REWRITE(Expression, node->cond(), node->set_cond(replacement)); |
| 163 } |
| 164 if (node->next() != nullptr) { |
| 165 AST_REWRITE(Statement, node->next(), node->set_next(replacement)); |
| 166 } |
| 167 AST_REWRITE(Statement, node->body(), node->set_body(replacement)); |
| 168 } |
| 169 |
| 170 |
| 171 void AstExpressionRewriter::VisitForInStatement(ForInStatement* node) { |
| 172 AST_REWRITE(Expression, node->each(), node->set_each(replacement)); |
| 173 AST_REWRITE(Expression, node->subject(), node->set_subject(replacement)); |
| 174 AST_REWRITE(Statement, node->body(), node->set_body(replacement)); |
| 175 } |
| 176 |
| 177 |
| 178 void AstExpressionRewriter::VisitForOfStatement(ForOfStatement* node) { |
| 179 AST_REWRITE(Expression, node->each(), node->set_each(replacement)); |
| 180 AST_REWRITE(Expression, node->assign_iterator(), |
| 181 node->set_assign_iterator(replacement)); |
| 182 AST_REWRITE(Expression, node->next_result(), |
| 183 node->set_next_result(replacement)); |
| 184 AST_REWRITE(Expression, node->result_done(), |
| 185 node->set_result_done(replacement)); |
| 186 AST_REWRITE(Expression, node->assign_each(), |
| 187 node->set_assign_each(replacement)); |
| 188 AST_REWRITE(Expression, node->subject(), node->set_subject(replacement)); |
| 189 AST_REWRITE(Statement, node->body(), node->set_body(replacement)); |
| 190 } |
| 191 |
| 192 |
| 193 void AstExpressionRewriter::VisitTryCatchStatement(TryCatchStatement* node) { |
| 194 AST_REWRITE(Block, node->try_block(), node->set_try_block(replacement)); |
| 195 // Not visiting the variable. |
| 196 AST_REWRITE(Block, node->catch_block(), node->set_catch_block(replacement)); |
| 197 } |
| 198 |
| 199 |
| 200 void AstExpressionRewriter::VisitTryFinallyStatement( |
| 201 TryFinallyStatement* node) { |
| 202 AST_REWRITE(Block, node->try_block(), node->set_try_block(replacement)); |
| 203 AST_REWRITE(Block, node->finally_block(), |
| 204 node->set_finally_block(replacement)); |
| 205 } |
| 206 |
| 207 |
| 208 void AstExpressionRewriter::VisitDebuggerStatement(DebuggerStatement* node) { |
| 209 NOTHING(); |
| 210 } |
| 211 |
| 212 |
| 213 void AstExpressionRewriter::VisitFunctionLiteral(FunctionLiteral* node) { |
| 214 REWRITE_THIS(node); |
| 215 VisitDeclarations(node->scope()->declarations()); |
| 216 ZoneList<Statement*>* body = node->body(); |
| 217 if (body != nullptr) VisitStatements(body); |
| 218 } |
| 219 |
| 220 |
| 221 void AstExpressionRewriter::VisitClassLiteral(ClassLiteral* node) { |
| 222 REWRITE_THIS(node); |
| 223 // Not visiting `class_variable_proxy_`. |
| 224 Expression* extends = node->extends(); |
| 225 if (extends != nullptr) { |
| 226 AST_REWRITE(Expression, extends, node->set_extends(replacement)); |
| 227 } |
| 228 AST_REWRITE(FunctionLiteral, node->constructor(), |
| 229 node->set_constructor(replacement)); |
| 230 ZoneList<typename ClassLiteral::Property*>* properties = node->properties(); |
| 231 for (int i = 0; i < properties->length(); i++) { |
| 232 VisitObjectLiteralProperty(properties->at(i)); |
| 233 } |
| 234 } |
| 235 |
| 236 |
| 237 void AstExpressionRewriter::VisitNativeFunctionLiteral( |
| 238 NativeFunctionLiteral* node) { |
| 239 REWRITE_THIS(node); |
| 240 NOTHING(); |
| 241 } |
| 242 |
| 243 |
| 244 void AstExpressionRewriter::VisitConditional(Conditional* node) { |
| 245 REWRITE_THIS(node); |
| 246 AST_REWRITE(Expression, node->condition(), node->set_condition(replacement)); |
| 247 AST_REWRITE(Expression, node->then_expression(), |
| 248 node->set_then_expression(replacement)); |
| 249 AST_REWRITE(Expression, node->else_expression(), |
| 250 node->set_else_expression(replacement)); |
| 251 } |
| 252 |
| 253 |
| 254 void AstExpressionRewriter::VisitVariableProxy(VariableProxy* node) { |
| 255 REWRITE_THIS(node); |
| 256 NOTHING(); |
| 257 } |
| 258 |
| 259 |
| 260 void AstExpressionRewriter::VisitLiteral(Literal* node) { |
| 261 REWRITE_THIS(node); |
| 262 NOTHING(); |
| 263 } |
| 264 |
| 265 |
| 266 void AstExpressionRewriter::VisitRegExpLiteral(RegExpLiteral* node) { |
| 267 REWRITE_THIS(node); |
| 268 NOTHING(); |
| 269 } |
| 270 |
| 271 |
| 272 void AstExpressionRewriter::VisitObjectLiteral(ObjectLiteral* node) { |
| 273 REWRITE_THIS(node); |
| 274 ZoneList<typename ObjectLiteral::Property*>* properties = node->properties(); |
| 275 for (int i = 0; i < properties->length(); i++) { |
| 276 VisitObjectLiteralProperty(properties->at(i)); |
| 277 } |
| 278 } |
| 279 |
| 280 |
| 281 void AstExpressionRewriter::VisitObjectLiteralProperty( |
| 282 ObjectLiteralProperty* property) { |
| 283 if (property == nullptr) return; |
| 284 AST_REWRITE(Expression, property->key(), property->set_key(replacement)); |
| 285 AST_REWRITE(Expression, property->value(), property->set_value(replacement)); |
| 286 } |
| 287 |
| 288 |
| 289 void AstExpressionRewriter::VisitArrayLiteral(ArrayLiteral* node) { |
| 290 REWRITE_THIS(node); |
| 291 VisitExpressions(node->values()); |
| 292 } |
| 293 |
| 294 |
| 295 void AstExpressionRewriter::VisitAssignment(Assignment* node) { |
| 296 REWRITE_THIS(node); |
| 297 AST_REWRITE(Expression, node->target(), node->set_target(replacement)); |
| 298 AST_REWRITE(Expression, node->value(), node->set_value(replacement)); |
| 299 } |
| 300 |
| 301 |
| 302 void AstExpressionRewriter::VisitYield(Yield* node) { |
| 303 REWRITE_THIS(node); |
| 304 AST_REWRITE(Expression, node->generator_object(), |
| 305 node->set_generator_object(replacement)); |
| 306 AST_REWRITE(Expression, node->expression(), |
| 307 node->set_expression(replacement)); |
| 308 } |
| 309 |
| 310 |
| 311 void AstExpressionRewriter::VisitThrow(Throw* node) { |
| 312 REWRITE_THIS(node); |
| 313 AST_REWRITE(Expression, node->exception(), node->set_exception(replacement)); |
| 314 } |
| 315 |
| 316 |
| 317 void AstExpressionRewriter::VisitProperty(Property* node) { |
| 318 REWRITE_THIS(node); |
| 319 if (node == nullptr) return; |
| 320 AST_REWRITE(Expression, node->obj(), node->set_obj(replacement)); |
| 321 AST_REWRITE(Expression, node->key(), node->set_key(replacement)); |
| 322 } |
| 323 |
| 324 |
| 325 void AstExpressionRewriter::VisitCall(Call* node) { |
| 326 REWRITE_THIS(node); |
| 327 AST_REWRITE(Expression, node->expression(), |
| 328 node->set_expression(replacement)); |
| 329 VisitExpressions(node->arguments()); |
| 330 } |
| 331 |
| 332 |
| 333 void AstExpressionRewriter::VisitCallNew(CallNew* node) { |
| 334 REWRITE_THIS(node); |
| 335 AST_REWRITE(Expression, node->expression(), |
| 336 node->set_expression(replacement)); |
| 337 VisitExpressions(node->arguments()); |
| 338 } |
| 339 |
| 340 |
| 341 void AstExpressionRewriter::VisitCallRuntime(CallRuntime* node) { |
| 342 REWRITE_THIS(node); |
| 343 VisitExpressions(node->arguments()); |
| 344 } |
| 345 |
| 346 |
| 347 void AstExpressionRewriter::VisitUnaryOperation(UnaryOperation* node) { |
| 348 REWRITE_THIS(node); |
| 349 AST_REWRITE(Expression, node->expression(), |
| 350 node->set_expression(replacement)); |
| 351 } |
| 352 |
| 353 |
| 354 void AstExpressionRewriter::VisitCountOperation(CountOperation* node) { |
| 355 REWRITE_THIS(node); |
| 356 AST_REWRITE(Expression, node->expression(), |
| 357 node->set_expression(replacement)); |
| 358 } |
| 359 |
| 360 |
| 361 void AstExpressionRewriter::VisitBinaryOperation(BinaryOperation* node) { |
| 362 REWRITE_THIS(node); |
| 363 AST_REWRITE(Expression, node->left(), node->set_left(replacement)); |
| 364 AST_REWRITE(Expression, node->right(), node->set_right(replacement)); |
| 365 } |
| 366 |
| 367 |
| 368 void AstExpressionRewriter::VisitCompareOperation(CompareOperation* node) { |
| 369 REWRITE_THIS(node); |
| 370 AST_REWRITE(Expression, node->left(), node->set_left(replacement)); |
| 371 AST_REWRITE(Expression, node->right(), node->set_right(replacement)); |
| 372 } |
| 373 |
| 374 |
| 375 void AstExpressionRewriter::VisitSpread(Spread* node) { |
| 376 REWRITE_THIS(node); |
| 377 AST_REWRITE(Expression, node->expression(), |
| 378 node->set_expression(replacement)); |
| 379 } |
| 380 |
| 381 |
| 382 void AstExpressionRewriter::VisitThisFunction(ThisFunction* node) { |
| 383 REWRITE_THIS(node); |
| 384 NOTHING(); |
| 385 } |
| 386 |
| 387 |
| 388 void AstExpressionRewriter::VisitSuperPropertyReference( |
| 389 SuperPropertyReference* node) { |
| 390 REWRITE_THIS(node); |
| 391 AST_REWRITE(VariableProxy, node->this_var(), node->set_this_var(replacement)); |
| 392 AST_REWRITE(Expression, node->home_object(), |
| 393 node->set_home_object(replacement)); |
| 394 } |
| 395 |
| 396 |
| 397 void AstExpressionRewriter::VisitSuperCallReference(SuperCallReference* node) { |
| 398 REWRITE_THIS(node); |
| 399 AST_REWRITE(VariableProxy, node->this_var(), node->set_this_var(replacement)); |
| 400 AST_REWRITE(VariableProxy, node->new_target_var(), |
| 401 node->set_new_target_var(replacement)); |
| 402 AST_REWRITE(VariableProxy, node->this_function_var(), |
| 403 node->set_this_function_var(replacement)); |
| 404 } |
| 405 |
| 406 |
| 407 void AstExpressionRewriter::VisitCaseClause(CaseClause* node) { |
| 408 if (!node->is_default()) { |
| 409 AST_REWRITE(Expression, node->label(), node->set_label(replacement)); |
| 410 } |
| 411 VisitStatements(node->statements()); |
| 412 } |
| 413 |
| 414 |
| 415 void AstExpressionRewriter::VisitEmptyParentheses(EmptyParentheses* node) { |
| 416 NOTHING(); |
| 417 } |
| 418 |
| 419 |
| 420 void AstExpressionRewriter::VisitDoExpression(DoExpression* node) { |
| 421 REWRITE_THIS(node); |
| 422 AST_REWRITE(Block, node->block(), node->set_block(replacement)); |
| 423 AST_REWRITE(VariableProxy, node->result(), node->set_result(replacement)); |
| 424 } |
| 425 |
| 426 |
| 427 void AstExpressionRewriter::VisitRewritableAssignmentExpression( |
| 428 RewritableAssignmentExpression* node) { |
| 429 REWRITE_THIS(node); |
| 430 AST_REWRITE(Expression, node->expression(), |
| 431 node->set_expression(replacement)); |
| 432 } |
| 433 |
| 434 |
| 435 } // namespace internal |
| 436 } // namespace v8 |
OLD | NEW |