| OLD | NEW |
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "src/ast/ast-numbering.h" | 5 #include "src/ast/ast-numbering.h" |
| 6 | 6 |
| 7 #include "src/ast/ast.h" | 7 #include "src/ast/ast.h" |
| 8 #include "src/ast/scopes.h" | 8 #include "src/ast/scopes.h" |
| 9 | 9 |
| 10 namespace v8 { | 10 namespace v8 { |
| (...skipping 445 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 456 node->set_base_id(ReserveIdRange(ForStatement::num_ids())); | 456 node->set_base_id(ReserveIdRange(ForStatement::num_ids())); |
| 457 if (node->init() != NULL) Visit(node->init()); // Not part of loop. | 457 if (node->init() != NULL) Visit(node->init()); // Not part of loop. |
| 458 node->set_first_yield_id(yield_count_); | 458 node->set_first_yield_id(yield_count_); |
| 459 if (node->cond() != NULL) Visit(node->cond()); | 459 if (node->cond() != NULL) Visit(node->cond()); |
| 460 if (node->next() != NULL) Visit(node->next()); | 460 if (node->next() != NULL) Visit(node->next()); |
| 461 Visit(node->body()); | 461 Visit(node->body()); |
| 462 node->set_yield_count(yield_count_ - node->first_yield_id()); | 462 node->set_yield_count(yield_count_ - node->first_yield_id()); |
| 463 } | 463 } |
| 464 | 464 |
| 465 | 465 |
| 466 void AstNumberingVisitor::VisitClassLiteral(ClassLiteral* node) { | |
| 467 IncrementNodeCount(); | |
| 468 DisableCrankshaft(kClassLiteral); | |
| 469 node->set_base_id(ReserveIdRange(node->num_ids())); | |
| 470 if (node->extends()) Visit(node->extends()); | |
| 471 if (node->constructor()) Visit(node->constructor()); | |
| 472 if (node->class_variable_proxy()) { | |
| 473 VisitVariableProxy(node->class_variable_proxy()); | |
| 474 } | |
| 475 for (int i = 0; i < node->properties()->length(); i++) { | |
| 476 VisitObjectLiteralProperty(node->properties()->at(i)); | |
| 477 } | |
| 478 ReserveFeedbackSlots(node); | |
| 479 } | |
| 480 | |
| 481 | |
| 482 void AstNumberingVisitor::VisitObjectLiteral(ObjectLiteral* node) { | 466 void AstNumberingVisitor::VisitObjectLiteral(ObjectLiteral* node) { |
| 483 IncrementNodeCount(); | 467 IncrementNodeCount(); |
| 484 node->set_base_id(ReserveIdRange(node->num_ids())); | 468 node->set_base_id(ReserveIdRange(node->num_ids())); |
| 485 for (int i = 0; i < node->properties()->length(); i++) { | 469 for (int i = 0; i < node->properties()->length(); i++) { |
| 486 VisitObjectLiteralProperty(node->properties()->at(i)); | 470 VisitObjectLiteralProperty(node->properties()->at(i)); |
| 487 } | 471 } |
| 488 node->BuildConstantProperties(isolate_); | 472 node->BuildConstantProperties(isolate_); |
| 489 // Mark all computed expressions that are bound to a key that | 473 // Mark all computed expressions that are bound to a key that |
| 490 // is shadowed by a later occurrence of the same key. For the | 474 // is shadowed by a later occurrence of the same key. For the |
| 491 // marked expressions, no store code will be is emitted. | 475 // marked expressions, no store code will be is emitted. |
| (...skipping 108 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 600 } | 584 } |
| 601 | 585 |
| 602 | 586 |
| 603 bool AstNumbering::Renumber(Isolate* isolate, Zone* zone, | 587 bool AstNumbering::Renumber(Isolate* isolate, Zone* zone, |
| 604 FunctionLiteral* function) { | 588 FunctionLiteral* function) { |
| 605 AstNumberingVisitor visitor(isolate, zone); | 589 AstNumberingVisitor visitor(isolate, zone); |
| 606 return visitor.Renumber(function); | 590 return visitor.Renumber(function); |
| 607 } | 591 } |
| 608 } // namespace internal | 592 } // namespace internal |
| 609 } // namespace v8 | 593 } // namespace v8 |
| OLD | NEW |