summaryrefslogtreecommitdiff
path: root/deps/v8/src/parsing/parse-info.cc
diff options
context:
space:
mode:
Diffstat (limited to 'deps/v8/src/parsing/parse-info.cc')
-rw-r--r--deps/v8/src/parsing/parse-info.cc35
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