diff options
Diffstat (limited to 'deps/v8/src/parsing/parse-info.cc')
-rw-r--r-- | deps/v8/src/parsing/parse-info.cc | 35 |
1 files changed, 30 insertions, 5 deletions
diff --git a/deps/v8/src/parsing/parse-info.cc b/deps/v8/src/parsing/parse-info.cc index 129b00a2c2..3050e01b48 100644 --- a/deps/v8/src/parsing/parse-info.cc +++ b/deps/v8/src/parsing/parse-info.cc @@ -8,7 +8,10 @@ #include "src/ast/ast-value-factory.h" #include "src/ast/ast.h" #include "src/base/template-utils.h" +#include "src/compiler-dispatcher/compiler-dispatcher.h" +#include "src/counters.h" #include "src/heap/heap-inl.h" +#include "src/log.h" #include "src/objects-inl.h" #include "src/objects/scope-info.h" #include "src/zone/zone.h" @@ -21,7 +24,6 @@ ParseInfo::ParseInfo(AccountingAllocator* zone_allocator) flags_(0), extension_(nullptr), script_scope_(nullptr), - unicode_cache_(nullptr), stack_limit_(0), hash_seed_(0), function_kind_(FunctionKind::kNormalFunction), @@ -43,12 +45,24 @@ ParseInfo::ParseInfo(Isolate* isolate, AccountingAllocator* zone_allocator) : ParseInfo(zone_allocator) { set_hash_seed(isolate->heap()->HashSeed()); set_stack_limit(isolate->stack_guard()->real_climit()); - set_unicode_cache(isolate->unicode_cache()); set_runtime_call_stats(isolate->counters()->runtime_call_stats()); set_logger(isolate->logger()); set_ast_string_constants(isolate->ast_string_constants()); if (isolate->is_block_code_coverage()) set_block_coverage_enabled(); if (isolate->is_collecting_type_profile()) set_collect_type_profile(); + if (isolate->compiler_dispatcher()->IsEnabled()) { + parallel_tasks_.reset(new ParallelTasks(isolate->compiler_dispatcher())); + } + set_might_always_opt(FLAG_always_opt || FLAG_prepare_always_opt); + set_allow_lazy_compile(FLAG_lazy); + set_allow_natives_syntax(FLAG_allow_natives_syntax); + set_allow_harmony_public_fields(FLAG_harmony_public_fields); + set_allow_harmony_static_fields(FLAG_harmony_static_fields); + set_allow_harmony_dynamic_import(FLAG_harmony_dynamic_import); + set_allow_harmony_import_meta(FLAG_harmony_import_meta); + set_allow_harmony_numeric_separator(FLAG_harmony_numeric_separator); + set_allow_harmony_private_fields(FLAG_harmony_private_fields); + set_allow_harmony_private_methods(FLAG_harmony_private_methods); } ParseInfo::ParseInfo(Isolate* isolate) @@ -63,9 +77,10 @@ void ParseInfo::SetFunctionInfo(T function) { set_language_mode(function->language_mode()); set_function_kind(function->kind()); set_declaration(function->is_declaration()); - set_requires_instance_fields_initializer( - function->requires_instance_fields_initializer()); + set_requires_instance_members_initializer( + function->requires_instance_members_initializer()); set_toplevel(function->is_toplevel()); + set_is_oneshot_iife(function->is_oneshot_iife()); set_wrapped_as_function(function->is_wrapped()); } @@ -76,7 +91,7 @@ ParseInfo::ParseInfo(Isolate* isolate, Handle<SharedFunctionInfo> shared) // wrapped script at all. DCHECK_IMPLIES(is_toplevel(), !Script::cast(shared->script())->is_wrapped()); - set_allow_lazy_parsing(FLAG_lazy_inner_functions); + set_allow_lazy_parsing(true); set_asm_wasm_broken(shared->is_asm_wasm_broken()); set_start_position(shared->StartPosition()); @@ -225,5 +240,15 @@ void ParseInfo::set_script(Handle<Script> script) { } } +void ParseInfo::ParallelTasks::Enqueue(ParseInfo* outer_parse_info, + const AstRawString* function_name, + FunctionLiteral* literal) { + base::Optional<CompilerDispatcher::JobId> job_id = + dispatcher_->Enqueue(outer_parse_info, function_name, literal); + if (job_id) { + enqueued_jobs_.emplace_front(std::make_pair(literal, *job_id)); + } +} + } // namespace internal } // namespace v8 |