Chromium Code Reviews| Index: src/background-parsing-task.cc |
| diff --git a/src/background-parsing-task.cc b/src/background-parsing-task.cc |
| index cb31cc99827e8baafe3ce5ee20e70378c216ce2a..8fce32e5deaaabaa9b1c65ac7ea282f5e06678e7 100644 |
| --- a/src/background-parsing-task.cc |
| +++ b/src/background-parsing-task.cc |
| @@ -10,26 +10,33 @@ namespace internal { |
| BackgroundParsingTask::BackgroundParsingTask( |
| StreamedSource* source, ScriptCompiler::CompileOptions options, |
| int stack_size, Isolate* isolate) |
| - : source_(source), options_(options), stack_size_(stack_size) { |
| - // Prepare the data for the internalization phase and compilation phase, which |
| - // will happen in the main thread after parsing. |
| - source->info.Reset(new i::CompilationInfoWithZone(source->source_stream.get(), |
| - source->encoding, isolate)); |
| - source->info->MarkAsGlobal(); |
| - |
| - // We don't set the context to the CompilationInfo yet, because the background |
| - // thread cannot do anything with it anyway. We set it just before compilation |
| - // on the foreground thread. |
| + : source_(source), stack_size_(stack_size) { |
| DCHECK(options == ScriptCompiler::kProduceParserCache || |
| options == ScriptCompiler::kProduceCodeCache || |
| options == ScriptCompiler::kNoCompileOptions); |
| - source->allow_lazy = |
| - !i::Compiler::DebuggerWantsEagerCompilation(source->info.get()); |
| - if (!source->allow_lazy && options_ == ScriptCompiler::kProduceParserCache) { |
| + // Prepare the data for the internalization phase and compilation phase, which |
| + // will happen in the main thread after parsing. |
| + Zone* zone = new Zone(); |
| + ParseInfo* info = new ParseInfo(zone); |
| + source->zone.Reset(zone); |
| + source->info.Reset(info); |
| + info->set_isolate(isolate); |
| + info->set_source_stream(source->source_stream.get()); |
| + info->set_source_stream_encoding(source->encoding); |
| + info->set_hash_seed(isolate->heap()->HashSeed()); |
| + info->set_global(); |
| + info->set_unicode_cache(&source_->unicode_cache); |
| + |
| + bool disable_lazy = !Compiler::DebuggerWantsEagerCompilation(isolate); |
|
marja
2015/03/05 10:52:55
... shouldn't we disable_lazy exactly when Debugge
titzer
2015/03/05 20:18:31
Good catch, thankfully the test failed :-)
|
| + if (disable_lazy && options == ScriptCompiler::kProduceParserCache) { |
| // Producing cached data while parsing eagerly is not supported. |
| - options_ = ScriptCompiler::kNoCompileOptions; |
| + options = ScriptCompiler::kNoCompileOptions; |
| } |
| + |
| + info->set_compile_options(options); |
| + info->set_allow_lazy_parsing(!disable_lazy); |
| + source->allow_lazy = !disable_lazy; |
|
marja
2015/03/05 10:52:55
... and why do we need allow_lazy now that it's al
titzer
2015/03/05 20:18:31
Good point, I've removed both allow_lazy and hash_
|
| source->hash_seed = isolate->heap()->HashSeed(); |
| } |
| @@ -40,19 +47,19 @@ void BackgroundParsingTask::Run() { |
| DisallowHandleDereference no_deref; |
| ScriptData* script_data = NULL; |
| - if (options_ == ScriptCompiler::kProduceParserCache || |
| - options_ == ScriptCompiler::kProduceCodeCache) { |
| - source_->info->SetCachedData(&script_data, options_); |
| + ScriptCompiler::CompileOptions options = source_->info->compile_options(); |
| + if (options == ScriptCompiler::kProduceParserCache || |
| + options == ScriptCompiler::kProduceCodeCache) { |
| + source_->info->set_cached_data(&script_data); |
| } |
| uintptr_t stack_limit = |
| reinterpret_cast<uintptr_t>(&stack_limit) - stack_size_ * KB; |
| + source_->info->set_stack_limit(stack_limit); |
| // Parser needs to stay alive for finalizing the parsing on the main |
| // thread. Passing &parse_info is OK because Parser doesn't store it. |
| - source_->parser.Reset(new Parser(source_->info.get(), stack_limit, |
| - source_->hash_seed, |
| - &source_->unicode_cache)); |
| + source_->parser.Reset(new Parser(source_->info.get())); |
| source_->parser->set_allow_lazy(source_->allow_lazy); |
| source_->parser->ParseOnBackground(source_->info.get()); |