%PDF- %PDF-
Direktori : /home/vacivi36/vittasync.vacivitta.com.br/vittasync/node/deps/v8/src/parsing/ |
Current File : /home/vacivi36/vittasync.vacivitta.com.br/vittasync/node/deps/v8/src/parsing/parse-info.cc |
// Copyright 2016 the V8 project authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include "src/parsing/parse-info.h" #include "src/ast/ast-source-ranges.h" #include "src/ast/ast-value-factory.h" #include "src/ast/ast.h" #include "src/base/logging.h" #include "src/common/globals.h" #include "src/compiler-dispatcher/lazy-compile-dispatcher.h" #include "src/heap/heap-inl.h" #include "src/logging/counters.h" #include "src/logging/log.h" #include "src/numbers/hash-seed-inl.h" #include "src/objects/objects-inl.h" #include "src/objects/scope-info.h" #include "src/zone/zone.h" namespace v8 { namespace internal { UnoptimizedCompileFlags::UnoptimizedCompileFlags(Isolate* isolate, int script_id) : flags_(0), script_id_(script_id), function_kind_(FunctionKind::kNormalFunction), function_syntax_kind_(FunctionSyntaxKind::kDeclaration), parsing_while_debugging_(ParsingWhileDebugging::kNo) { set_coverage_enabled(!isolate->is_best_effort_code_coverage()); set_block_coverage_enabled(isolate->is_block_code_coverage()); set_might_always_turbofan(v8_flags.always_turbofan || v8_flags.prepare_always_turbofan); set_allow_natives_syntax(v8_flags.allow_natives_syntax); set_allow_lazy_compile(true); set_collect_source_positions(!v8_flags.enable_lazy_source_positions || isolate->NeedsDetailedOptimizedCodeLineInfo()); set_post_parallel_compile_tasks_for_eager_toplevel( v8_flags.parallel_compile_tasks_for_eager_toplevel); set_post_parallel_compile_tasks_for_lazy( v8_flags.parallel_compile_tasks_for_lazy); } // static UnoptimizedCompileFlags UnoptimizedCompileFlags::ForFunctionCompile( Isolate* isolate, Tagged<SharedFunctionInfo> shared) { Tagged<Script> script = Script::cast(shared->script()); UnoptimizedCompileFlags flags(isolate, script->id()); flags.SetFlagsForFunctionFromScript(script); flags.SetFlagsFromFunction(shared); flags.set_allow_lazy_parsing(true); flags.set_is_lazy_compile(true); #if V8_ENABLE_WEBASSEMBLY flags.set_is_asm_wasm_broken(shared->is_asm_wasm_broken()); #endif // V8_ENABLE_WEBASSEMBLY flags.set_is_repl_mode(shared->is_repl_mode()); // Do not support re-parsing top-level function of a wrapped script. DCHECK_IMPLIES(flags.is_toplevel(), !script->is_wrapped()); return flags; } // static UnoptimizedCompileFlags UnoptimizedCompileFlags::ForScriptCompile( Isolate* isolate, Tagged<Script> script) { UnoptimizedCompileFlags flags(isolate, script->id()); flags.SetFlagsForFunctionFromScript(script); flags.SetFlagsForToplevelCompile( script->IsUserJavaScript(), flags.outer_language_mode(), construct_repl_mode(script->is_repl_mode()), script->origin_options().IsModule() ? ScriptType::kModule : ScriptType::kClassic, v8_flags.lazy); if (script->is_wrapped()) { flags.set_function_syntax_kind(FunctionSyntaxKind::kWrapped); } return flags; } // static UnoptimizedCompileFlags UnoptimizedCompileFlags::ForToplevelCompile( Isolate* isolate, bool is_user_javascript, LanguageMode language_mode, REPLMode repl_mode, ScriptType type, bool lazy) { UnoptimizedCompileFlags flags(isolate, isolate->GetNextScriptId()); flags.SetFlagsForToplevelCompile(is_user_javascript, language_mode, repl_mode, type, lazy); flags.set_compile_hints_magic_enabled(v8_flags.compile_hints_magic || isolate->allow_compile_hints_magic()); LOG(isolate, ScriptEvent(ScriptEventType::kReserveId, flags.script_id())); return flags; } // static UnoptimizedCompileFlags UnoptimizedCompileFlags::ForToplevelFunction( const UnoptimizedCompileFlags toplevel_flags, const FunctionLiteral* literal) { DCHECK(toplevel_flags.is_toplevel()); DCHECK(!literal->is_toplevel()); // Replicate the toplevel flags, then setup the function-specific flags. UnoptimizedCompileFlags flags = toplevel_flags; flags.SetFlagsFromFunction(literal); return flags; } // static UnoptimizedCompileFlags UnoptimizedCompileFlags::ForTest(Isolate* isolate) { return UnoptimizedCompileFlags(isolate, Script::kTemporaryScriptId); } template <typename T> void UnoptimizedCompileFlags::SetFlagsFromFunction(T function) { set_outer_language_mode(function->language_mode()); set_function_kind(function->kind()); set_function_syntax_kind(function->syntax_kind()); set_requires_instance_members_initializer( function->requires_instance_members_initializer()); set_class_scope_has_private_brand(function->class_scope_has_private_brand()); set_has_static_private_methods_or_accessors( function->has_static_private_methods_or_accessors()); set_private_name_lookup_skips_outer_class( function->private_name_lookup_skips_outer_class()); set_is_toplevel(function->is_toplevel()); } void UnoptimizedCompileFlags::SetFlagsForToplevelCompile( bool is_user_javascript, LanguageMode language_mode, REPLMode repl_mode, ScriptType type, bool lazy) { set_is_toplevel(true); set_allow_lazy_parsing(lazy); set_allow_lazy_compile(lazy); set_outer_language_mode( stricter_language_mode(outer_language_mode(), language_mode)); set_is_repl_mode((repl_mode == REPLMode::kYes)); set_is_module(type == ScriptType::kModule); DCHECK_IMPLIES(is_eval(), !is_module()); set_block_coverage_enabled(block_coverage_enabled() && is_user_javascript); } void UnoptimizedCompileFlags::SetFlagsForFunctionFromScript( Tagged<Script> script) { DCHECK_EQ(script_id(), script->id()); set_is_eval(script->compilation_type() == Script::CompilationType::kEval); if (is_eval()) { DCHECK(script->has_eval_from_shared()); set_outer_language_mode(script->eval_from_shared()->language_mode()); } set_is_module(script->origin_options().IsModule()); DCHECK_IMPLIES(is_eval(), !is_module()); set_block_coverage_enabled(block_coverage_enabled() && script->IsUserJavaScript()); } ReusableUnoptimizedCompileState::ReusableUnoptimizedCompileState( Isolate* isolate) : hash_seed_(HashSeed(isolate)), allocator_(isolate->allocator()), v8_file_logger_(isolate->v8_file_logger()), dispatcher_(isolate->lazy_compile_dispatcher()), ast_string_constants_(isolate->ast_string_constants()), ast_raw_string_zone_(allocator_, "unoptimized-compile-ast-raw-string-zone"), single_parse_zone_(allocator_, "unoptimized-compile-parse-zone"), ast_value_factory_( new AstValueFactory(ast_raw_string_zone(), single_parse_zone(), ast_string_constants(), hash_seed())) {} ReusableUnoptimizedCompileState::ReusableUnoptimizedCompileState( LocalIsolate* isolate) : hash_seed_(HashSeed(isolate)), allocator_(isolate->allocator()), v8_file_logger_(isolate->main_thread_logger()), dispatcher_(isolate->lazy_compile_dispatcher()), ast_string_constants_(isolate->ast_string_constants()), ast_raw_string_zone_(allocator_, "unoptimized-compile-ast-raw-string-zone"), single_parse_zone_(allocator_, "unoptimized-compile-parse-zone"), ast_value_factory_( new AstValueFactory(ast_raw_string_zone(), single_parse_zone(), ast_string_constants(), hash_seed())) {} ReusableUnoptimizedCompileState::~ReusableUnoptimizedCompileState() = default; ParseInfo::ParseInfo(const UnoptimizedCompileFlags flags, UnoptimizedCompileState* state, ReusableUnoptimizedCompileState* reusable_state, uintptr_t stack_limit, RuntimeCallStats* runtime_call_stats) : flags_(flags), state_(state), reusable_state_(reusable_state), extension_(nullptr), script_scope_(nullptr), stack_limit_(stack_limit), parameters_end_pos_(kNoSourcePosition), max_function_literal_id_(kFunctionLiteralIdInvalid), character_stream_(nullptr), function_name_(nullptr), runtime_call_stats_(runtime_call_stats), source_range_map_(nullptr), literal_(nullptr), allow_eval_cache_(false), #if V8_ENABLE_WEBASSEMBLY contains_asm_module_(false), #endif // V8_ENABLE_WEBASSEMBLY language_mode_(flags.outer_language_mode()), is_background_compilation_(false), is_streaming_compilation_(false) { if (flags.block_coverage_enabled()) { AllocateSourceRangeMap(); } } ParseInfo::ParseInfo(Isolate* isolate, const UnoptimizedCompileFlags flags, UnoptimizedCompileState* state, ReusableUnoptimizedCompileState* reusable_state) : ParseInfo(flags, state, reusable_state, isolate->stack_guard()->real_climit(), isolate->counters()->runtime_call_stats()) {} ParseInfo::ParseInfo(LocalIsolate* isolate, const UnoptimizedCompileFlags flags, UnoptimizedCompileState* state, ReusableUnoptimizedCompileState* reusable_state, uintptr_t stack_limit) : ParseInfo(flags, state, reusable_state, stack_limit, isolate->runtime_call_stats()) {} ParseInfo::~ParseInfo() { reusable_state_->NotifySingleParseCompleted(); } DeclarationScope* ParseInfo::scope() const { return literal()->scope(); } template <typename IsolateT> Handle<Script> ParseInfo::CreateScript( IsolateT* isolate, Handle<String> source, MaybeHandle<FixedArray> maybe_wrapped_arguments, ScriptOriginOptions origin_options, NativesFlag natives) { // Create a script object describing the script to be compiled. DCHECK(flags().script_id() >= 0 || flags().script_id() == Script::kTemporaryScriptId); auto event = ScriptEventType::kCreate; if (is_streaming_compilation()) { event = is_background_compilation() ? ScriptEventType::kStreamingCompileBackground : ScriptEventType::kStreamingCompileForeground; } else if (is_background_compilation()) { event = ScriptEventType::kBackgroundCompile; } Handle<Script> script = isolate->factory()->NewScriptWithId(source, flags().script_id(), event); DisallowGarbageCollection no_gc; Tagged<Script> raw_script = *script; switch (natives) { case EXTENSION_CODE: raw_script->set_type(Script::Type::kExtension); break; case INSPECTOR_CODE: raw_script->set_type(Script::Type::kInspector); break; case NOT_NATIVES_CODE: break; } raw_script->set_origin_options(origin_options); raw_script->set_is_repl_mode(flags().is_repl_mode()); DCHECK_EQ(is_wrapped_as_function(), !maybe_wrapped_arguments.is_null()); if (is_wrapped_as_function()) { raw_script->set_wrapped_arguments( *maybe_wrapped_arguments.ToHandleChecked()); } else if (flags().is_eval()) { raw_script->set_compilation_type(Script::CompilationType::kEval); } CheckFlagsForToplevelCompileFromScript(raw_script); return script; } template EXPORT_TEMPLATE_DEFINE(V8_EXPORT_PRIVATE) Handle<Script> ParseInfo::CreateScript( Isolate* isolate, Handle<String> source, MaybeHandle<FixedArray> maybe_wrapped_arguments, ScriptOriginOptions origin_options, NativesFlag natives); template EXPORT_TEMPLATE_DEFINE(V8_EXPORT_PRIVATE) Handle<Script> ParseInfo::CreateScript( LocalIsolate* isolate, Handle<String> source, MaybeHandle<FixedArray> maybe_wrapped_arguments, ScriptOriginOptions origin_options, NativesFlag natives); void ParseInfo::AllocateSourceRangeMap() { DCHECK(flags().block_coverage_enabled()); DCHECK_NULL(source_range_map()); set_source_range_map(zone()->New<SourceRangeMap>(zone())); } void ParseInfo::ResetCharacterStream() { character_stream_.reset(); } void ParseInfo::set_character_stream( std::unique_ptr<Utf16CharacterStream> character_stream) { DCHECK_NULL(character_stream_); character_stream_.swap(character_stream); } void ParseInfo::CheckFlagsForToplevelCompileFromScript(Tagged<Script> script) { CheckFlagsForFunctionFromScript(script); DCHECK(flags().is_toplevel()); DCHECK_EQ(flags().is_repl_mode(), script->is_repl_mode()); if (script->is_wrapped()) { DCHECK_EQ(flags().function_syntax_kind(), FunctionSyntaxKind::kWrapped); } } void ParseInfo::CheckFlagsForFunctionFromScript(Tagged<Script> script) { DCHECK_EQ(flags().script_id(), script->id()); // We set "is_eval" for wrapped scripts to get an outer declaration scope. // This is a bit hacky, but ok since we can't be both eval and wrapped. DCHECK_EQ(flags().is_eval() && !script->is_wrapped(), script->compilation_type() == Script::CompilationType::kEval); DCHECK_EQ(flags().is_module(), script->origin_options().IsModule()); DCHECK_IMPLIES(flags().block_coverage_enabled() && script->IsUserJavaScript(), source_range_map() != nullptr); } } // namespace internal } // namespace v8