Chromium Code Reviews| 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/v8.h" | 5 #include "src/v8.h" |
| 6 | 6 |
| 7 #include "src/compiler.h" | 7 #include "src/compiler.h" |
| 8 | 8 |
| 9 #include "src/ast-numbering.h" | 9 #include "src/ast-numbering.h" |
| 10 #include "src/bootstrapper.h" | 10 #include "src/bootstrapper.h" |
| (...skipping 723 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 734 Handle<Context> native_context(function->context()->native_context()); | 734 Handle<Context> native_context(function->context()->native_context()); |
| 735 SharedFunctionInfo::AddToOptimizedCodeMap(shared, native_context, code, | 735 SharedFunctionInfo::AddToOptimizedCodeMap(shared, native_context, code, |
| 736 literals, info->osr_ast_id()); | 736 literals, info->osr_ast_id()); |
| 737 } | 737 } |
| 738 } | 738 } |
| 739 | 739 |
| 740 | 740 |
| 741 static bool Renumber(CompilationInfo* info) { | 741 static bool Renumber(CompilationInfo* info) { |
| 742 if (!AstNumbering::Renumber(info->function(), info->zone())) return false; | 742 if (!AstNumbering::Renumber(info->function(), info->zone())) return false; |
| 743 if (!info->shared_info().is_null()) { | 743 if (!info->shared_info().is_null()) { |
| 744 info->shared_info()->set_ast_node_count(info->function()->ast_node_count()); | 744 FunctionLiteral* lit = info->function(); |
| 745 info->shared_info()->set_ast_node_count(lit->ast_node_count()); | |
| 746 info->shared_info()->set_bailout_reason(lit->dont_optimize_reason()); | |
|
wingo
2014/10/27 15:08:20
As mstarzinger points out, this should probably be
| |
| 747 info->shared_info()->set_dont_cache(lit->flags()->Contains(kDontCache)); | |
| 745 } | 748 } |
| 746 return true; | 749 return true; |
| 747 } | 750 } |
| 748 | 751 |
| 749 | 752 |
| 750 bool Compiler::Analyze(CompilationInfo* info) { | 753 bool Compiler::Analyze(CompilationInfo* info) { |
| 751 DCHECK(info->function() != NULL); | 754 DCHECK(info->function() != NULL); |
| 752 if (!Rewriter::Rewrite(info)) return false; | 755 if (!Rewriter::Rewrite(info)) return false; |
| 753 if (!Scope::Analyze(info)) return false; | 756 if (!Scope::Analyze(info)) return false; |
| 754 if (!Renumber(info)) return false; | 757 if (!Renumber(info)) return false; |
| (...skipping 712 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1467 AllowHandleDereference allow_deref; | 1470 AllowHandleDereference allow_deref; |
| 1468 bool tracing_on = info()->IsStub() | 1471 bool tracing_on = info()->IsStub() |
| 1469 ? FLAG_trace_hydrogen_stubs | 1472 ? FLAG_trace_hydrogen_stubs |
| 1470 : (FLAG_trace_hydrogen && | 1473 : (FLAG_trace_hydrogen && |
| 1471 info()->closure()->PassesFilter(FLAG_trace_hydrogen_filter)); | 1474 info()->closure()->PassesFilter(FLAG_trace_hydrogen_filter)); |
| 1472 return (tracing_on && | 1475 return (tracing_on && |
| 1473 base::OS::StrChr(const_cast<char*>(FLAG_trace_phase), name_[0]) != NULL); | 1476 base::OS::StrChr(const_cast<char*>(FLAG_trace_phase), name_[0]) != NULL); |
| 1474 } | 1477 } |
| 1475 | 1478 |
| 1476 } } // namespace v8::internal | 1479 } } // namespace v8::internal |
| OLD | NEW |