Chromium Code Reviews| Index: src/compiler.cc |
| diff --git a/src/compiler.cc b/src/compiler.cc |
| index 92331c6a02d8296ab78b7982651e7a35ae93cd12..179ca47c6c2b9f2ecb202a9b4fd13aba216af3aa 100644 |
| --- a/src/compiler.cc |
| +++ b/src/compiler.cc |
| @@ -647,12 +647,7 @@ static void RecordFunctionCompilation(Logger::LogEventsAndTags tag, |
| static bool CompileUnoptimizedCode(CompilationInfo* info) { |
| DCHECK(AllowCompilation::IsAllowed(info->isolate())); |
| - DCHECK(info->function() != NULL); |
| - if (!Rewriter::Rewrite(info)) return false; |
| - if (!Scope::Analyze(info)) return false; |
| - DCHECK(info->scope() != NULL); |
| - |
| - if (!FullCodeGenerator::MakeCode(info)) { |
| + if (!Compiler::Analyze(info) || !FullCodeGenerator::MakeCode(info)) { |
|
wingo
2014/10/28 08:31:02
This part changed since the last patch to signal S
|
| Isolate* isolate = info->isolate(); |
| if (!isolate->has_pending_exception()) isolate->StackOverflow(); |
| return false; |
| @@ -673,7 +668,6 @@ MUST_USE_RESULT static MaybeHandle<Code> GetUnoptimizedCodeCommon( |
| shared->set_strict_mode(lit->strict_mode()); |
| SetExpectedNofPropertiesFromEstimate(shared, lit->expected_property_count()); |
| shared->set_bailout_reason(lit->dont_optimize_reason()); |
| - shared->set_ast_node_count(lit->ast_node_count()); |
| // Compile unoptimized code. |
| if (!CompileUnoptimizedCode(info)) return MaybeHandle<Code>(); |
| @@ -743,18 +737,33 @@ static void InsertCodeIntoOptimizedCodeMap(CompilationInfo* info) { |
| } |
| -static bool CompileOptimizedPrologue(CompilationInfo* info) { |
| - if (!Parser::Parse(info)) return false; |
| +static bool Renumber(CompilationInfo* info) { |
| + if (!AstNumbering::Renumber(info->function(), info->zone())) return false; |
| + if (!info->shared_info().is_null()) { |
| + info->shared_info()->set_ast_node_count(info->function()->ast_node_count()); |
| + } |
| + return true; |
| +} |
| + |
| + |
| +bool Compiler::Analyze(CompilationInfo* info) { |
| + DCHECK(info->function() != NULL); |
| if (!Rewriter::Rewrite(info)) return false; |
| if (!Scope::Analyze(info)) return false; |
| - if (!AstNumbering::Renumber(info->function(), info->zone())) return false; |
| + if (!Renumber(info)) return false; |
| DCHECK(info->scope() != NULL); |
| return true; |
| } |
| +bool Compiler::ParseAndAnalyze(CompilationInfo* info) { |
| + if (!Parser::Parse(info)) return false; |
| + return Compiler::Analyze(info); |
| +} |
| + |
| + |
| static bool GetOptimizedCodeNow(CompilationInfo* info) { |
| - if (!CompileOptimizedPrologue(info)) return false; |
| + if (!Compiler::ParseAndAnalyze(info)) return false; |
| TimerEventScope<TimerEventRecompileSynchronous> timer(info->isolate()); |
| @@ -796,7 +805,7 @@ static bool GetOptimizedCodeLater(CompilationInfo* info) { |
| } |
| CompilationHandleScope handle_scope(info); |
| - if (!CompileOptimizedPrologue(info)) return false; |
| + if (!Compiler::ParseAndAnalyze(info)) return false; |
| info->SaveHandles(); // Copy handles to the compilation handle scope. |
| TimerEventScope<TimerEventRecompileSynchronous> timer(info->isolate()); |
| @@ -910,6 +919,8 @@ bool Compiler::EnsureCompiled(Handle<JSFunction> function, |
| // TODO(turbofan): In the future, unoptimized code with deopt support could |
| // be generated lazily once deopt is triggered. |
| bool Compiler::EnsureDeoptimizationSupport(CompilationInfo* info) { |
| + DCHECK(info->function() != NULL); |
| + DCHECK(info->scope() != NULL); |
| if (!info->shared_info()->has_deoptimization_support()) { |
| CompilationInfoWithZone unoptimized(info->shared_info()); |
| // Note that we use the same AST that we will use for generating the |
| @@ -1304,7 +1315,7 @@ Handle<SharedFunctionInfo> Compiler::BuildFunctionInfo( |
| Handle<Code> code = isolate->builtins()->CompileLazy(); |
| info.SetCode(code); |
| scope_info = Handle<ScopeInfo>(ScopeInfo::Empty(isolate)); |
| - } else if (FullCodeGenerator::MakeCode(&info)) { |
| + } else if (Renumber(&info) && FullCodeGenerator::MakeCode(&info)) { |
| DCHECK(!info.code().is_null()); |
| scope_info = ScopeInfo::Create(info.scope(), info.zone()); |
| } else { |