| OLD | NEW |
| 1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 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/compiler/ast-graph-builder.h" | 5 #include "src/compiler/ast-graph-builder.h" |
| 6 | 6 |
| 7 #include "src/compiler.h" | 7 #include "src/compiler.h" |
| 8 #include "src/compiler/ast-loop-assignment-analyzer.h" | 8 #include "src/compiler/ast-loop-assignment-analyzer.h" |
| 9 #include "src/compiler/control-builders.h" | 9 #include "src/compiler/control-builders.h" |
| 10 #include "src/compiler/js-type-feedback.h" | 10 #include "src/compiler/js-type-feedback.h" |
| (...skipping 987 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 998 | 998 |
| 999 void AstGraphBuilder::VisitBlock(Block* stmt) { | 999 void AstGraphBuilder::VisitBlock(Block* stmt) { |
| 1000 BlockBuilder block(this); | 1000 BlockBuilder block(this); |
| 1001 ControlScopeForBreakable scope(this, stmt, &block); | 1001 ControlScopeForBreakable scope(this, stmt, &block); |
| 1002 if (stmt->labels() != NULL) block.BeginBlock(); | 1002 if (stmt->labels() != NULL) block.BeginBlock(); |
| 1003 if (stmt->scope() == NULL) { | 1003 if (stmt->scope() == NULL) { |
| 1004 // Visit statements in the same scope, no declarations. | 1004 // Visit statements in the same scope, no declarations. |
| 1005 VisitStatements(stmt->statements()); | 1005 VisitStatements(stmt->statements()); |
| 1006 } else { | 1006 } else { |
| 1007 // Visit declarations and statements in a block scope. | 1007 // Visit declarations and statements in a block scope. |
| 1008 Node* context = BuildLocalBlockContext(stmt->scope()); | 1008 if (stmt->scope()->ContextLocalCount() > 0) { |
| 1009 ContextScope scope(this, stmt->scope(), context); | 1009 Node* context = BuildLocalBlockContext(stmt->scope()); |
| 1010 VisitDeclarations(stmt->scope()->declarations()); | 1010 ContextScope scope(this, stmt->scope(), context); |
| 1011 VisitStatements(stmt->statements()); | 1011 VisitDeclarations(stmt->scope()->declarations()); |
| 1012 VisitStatements(stmt->statements()); |
| 1013 } else { |
| 1014 VisitDeclarations(stmt->scope()->declarations()); |
| 1015 VisitStatements(stmt->statements()); |
| 1016 } |
| 1012 } | 1017 } |
| 1013 if (stmt->labels() != NULL) block.EndBlock(); | 1018 if (stmt->labels() != NULL) block.EndBlock(); |
| 1014 } | 1019 } |
| 1015 | 1020 |
| 1016 | 1021 |
| 1017 void AstGraphBuilder::VisitModuleStatement(ModuleStatement* stmt) { | 1022 void AstGraphBuilder::VisitModuleStatement(ModuleStatement* stmt) { |
| 1018 UNREACHABLE(); | 1023 UNREACHABLE(); |
| 1019 } | 1024 } |
| 1020 | 1025 |
| 1021 | 1026 |
| (...skipping 434 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1456 ast_context()->ProduceValue(value); | 1461 ast_context()->ProduceValue(value); |
| 1457 } | 1462 } |
| 1458 | 1463 |
| 1459 | 1464 |
| 1460 void AstGraphBuilder::VisitClassLiteral(ClassLiteral* expr) { | 1465 void AstGraphBuilder::VisitClassLiteral(ClassLiteral* expr) { |
| 1461 if (expr->scope() == NULL) { | 1466 if (expr->scope() == NULL) { |
| 1462 // Visit class literal in the same scope, no declarations. | 1467 // Visit class literal in the same scope, no declarations. |
| 1463 VisitClassLiteralContents(expr); | 1468 VisitClassLiteralContents(expr); |
| 1464 } else { | 1469 } else { |
| 1465 // Visit declarations and class literal in a block scope. | 1470 // Visit declarations and class literal in a block scope. |
| 1466 Node* context = BuildLocalBlockContext(expr->scope()); | 1471 if (expr->scope()->ContextLocalCount() > 0) { |
| 1467 ContextScope scope(this, expr->scope(), context); | 1472 Node* context = BuildLocalBlockContext(expr->scope()); |
| 1468 VisitDeclarations(expr->scope()->declarations()); | 1473 ContextScope scope(this, expr->scope(), context); |
| 1469 VisitClassLiteralContents(expr); | 1474 VisitDeclarations(expr->scope()->declarations()); |
| 1475 VisitClassLiteralContents(expr); |
| 1476 } else { |
| 1477 VisitDeclarations(expr->scope()->declarations()); |
| 1478 VisitClassLiteralContents(expr); |
| 1479 } |
| 1470 } | 1480 } |
| 1471 } | 1481 } |
| 1472 | 1482 |
| 1473 | 1483 |
| 1474 void AstGraphBuilder::VisitClassLiteralContents(ClassLiteral* expr) { | 1484 void AstGraphBuilder::VisitClassLiteralContents(ClassLiteral* expr) { |
| 1475 Node* class_name = expr->raw_name() ? jsgraph()->Constant(expr->name()) | 1485 Node* class_name = expr->raw_name() ? jsgraph()->Constant(expr->name()) |
| 1476 : jsgraph()->UndefinedConstant(); | 1486 : jsgraph()->UndefinedConstant(); |
| 1477 | 1487 |
| 1478 // The class name is expected on the operand stack. | 1488 // The class name is expected on the operand stack. |
| 1479 environment()->Push(class_name); | 1489 environment()->Push(class_name); |
| (...skipping 2070 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3550 // Phi does not exist yet, introduce one. | 3560 // Phi does not exist yet, introduce one. |
| 3551 value = NewPhi(inputs, value, control); | 3561 value = NewPhi(inputs, value, control); |
| 3552 value->ReplaceInput(inputs - 1, other); | 3562 value->ReplaceInput(inputs - 1, other); |
| 3553 } | 3563 } |
| 3554 return value; | 3564 return value; |
| 3555 } | 3565 } |
| 3556 | 3566 |
| 3557 } // namespace compiler | 3567 } // namespace compiler |
| 3558 } // namespace internal | 3568 } // namespace internal |
| 3559 } // namespace v8 | 3569 } // namespace v8 |
| OLD | NEW |