blob: d8cc9735a4e21dbd946d533743628171f9837fe2 [file] [log] [blame]
// Copyright 2017 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.
#ifndef V8_OBJECTS_SCRIPT_INL_H_
#define V8_OBJECTS_SCRIPT_INL_H_
#include "src/objects/managed.h"
#include "src/objects/objects.h"
#include "src/objects/script.h"
#include "src/objects/shared-function-info.h"
#include "src/objects/smi-inl.h"
#include "src/objects/string-inl.h"
#include "src/objects/string.h"
// Has to be the last include (doesn't have include guards):
#include "src/objects/object-macros.h"
namespace v8 {
namespace internal {
#include "torque-generated/src/objects/script-tq-inl.inc"
TQ_OBJECT_CONSTRUCTORS_IMPL(Script)
NEVER_READ_ONLY_SPACE_IMPL(Script)
#if V8_ENABLE_WEBASSEMBLY
ACCESSORS_CHECKED(Script, wasm_breakpoint_infos, Tagged<FixedArray>,
kEvalFromSharedOrWrappedArgumentsOffset,
this->type() == Type::kWasm)
ACCESSORS_CHECKED(Script, wasm_managed_native_module, Tagged<Object>,
kEvalFromPositionOffset, this->type() == Type::kWasm)
ACCESSORS_CHECKED(Script, wasm_weak_instance_list, Tagged<WeakArrayList>,
kSharedFunctionInfosOffset, this->type() == Type::kWasm)
#define CHECK_SCRIPT_NOT_WASM this->type() != Type::kWasm
#else
#define CHECK_SCRIPT_NOT_WASM true
#endif // V8_ENABLE_WEBASSEMBLY
Script::Type Script::type() const {
Tagged<Smi> value = TaggedField<Smi, kScriptTypeOffset>::load(*this);
return static_cast<Type>(value.value());
}
void Script::set_type(Type value) {
TaggedField<Smi, kScriptTypeOffset>::store(
*this, Smi::FromInt(static_cast<int>(value)));
}
ACCESSORS_CHECKED(Script, eval_from_shared_or_wrapped_arguments, Tagged<Object>,
kEvalFromSharedOrWrappedArgumentsOffset,
CHECK_SCRIPT_NOT_WASM)
SMI_ACCESSORS_CHECKED(Script, eval_from_position, kEvalFromPositionOffset,
CHECK_SCRIPT_NOT_WASM)
#undef CHECK_SCRIPT_NOT_WASM
ACCESSORS(Script, compiled_lazy_function_positions, Tagged<Object>,
kCompiledLazyFunctionPositionsOffset)
bool Script::is_wrapped() const {
return IsFixedArray(eval_from_shared_or_wrapped_arguments());
}
bool Script::has_eval_from_shared() const {
return IsSharedFunctionInfo(eval_from_shared_or_wrapped_arguments());
}
void Script::set_eval_from_shared(Tagged<SharedFunctionInfo> shared,
WriteBarrierMode mode) {
DCHECK(!is_wrapped());
set_eval_from_shared_or_wrapped_arguments(shared, mode);
}
Tagged<SharedFunctionInfo> Script::eval_from_shared() const {
DCHECK(has_eval_from_shared());
return SharedFunctionInfo::cast(eval_from_shared_or_wrapped_arguments());
}
void Script::set_wrapped_arguments(Tagged<FixedArray> value,
WriteBarrierMode mode) {
DCHECK(!has_eval_from_shared());
set_eval_from_shared_or_wrapped_arguments(value, mode);
}
Tagged<FixedArray> Script::wrapped_arguments() const {
DCHECK(is_wrapped());
return FixedArray::cast(eval_from_shared_or_wrapped_arguments());
}
DEF_GETTER(Script, shared_function_infos, Tagged<WeakFixedArray>) {
#if V8_ENABLE_WEBASSEMBLY
if (type() == Type::kWasm) {
return ReadOnlyRoots(GetHeap()).empty_weak_fixed_array();
}
#endif // V8_ENABLE_WEBASSEMBLY
return TaggedField<WeakFixedArray, kSharedFunctionInfosOffset>::load(*this);
}
void Script::set_shared_function_infos(Tagged<WeakFixedArray> value,
WriteBarrierMode mode) {
#if V8_ENABLE_WEBASSEMBLY
DCHECK_NE(Type::kWasm, type());
#endif // V8_ENABLE_WEBASSEMBLY
TaggedField<WeakFixedArray, kSharedFunctionInfosOffset>::store(*this, value);
CONDITIONAL_WRITE_BARRIER(*this, kSharedFunctionInfosOffset, value, mode);
}
int Script::shared_function_info_count() const {
return shared_function_infos()->length();
}
#if V8_ENABLE_WEBASSEMBLY
bool Script::has_wasm_breakpoint_infos() const {
return type() == Type::kWasm && wasm_breakpoint_infos()->length() > 0;
}
wasm::NativeModule* Script::wasm_native_module() const {
return Managed<wasm::NativeModule>::cast(wasm_managed_native_module())->raw();
}
bool Script::break_on_entry() const { return BreakOnEntryBit::decode(flags()); }
void Script::set_break_on_entry(bool value) {
set_flags(BreakOnEntryBit::update(flags(), value));
}
#endif // V8_ENABLE_WEBASSEMBLY
Script::CompilationType Script::compilation_type() {
return CompilationTypeBit::decode(flags());
}
void Script::set_compilation_type(CompilationType type) {
set_flags(CompilationTypeBit::update(flags(), type));
}
Script::CompilationState Script::compilation_state() {
return CompilationStateBit::decode(flags());
}
void Script::set_compilation_state(CompilationState state) {
set_flags(CompilationStateBit::update(flags(), state));
}
bool Script::produce_compile_hints() const {
return ProduceCompileHintsBit::decode(flags());
}
void Script::set_produce_compile_hints(bool produce_compile_hints) {
set_flags(ProduceCompileHintsBit::update(flags(), produce_compile_hints));
}
bool Script::deserialized() const { return DeserializedBit::decode(flags()); }
void Script::set_deserialized(bool value) {
set_flags(DeserializedBit::update(flags(), value));
}
bool Script::is_repl_mode() const { return IsReplModeBit::decode(flags()); }
void Script::set_is_repl_mode(bool value) {
set_flags(IsReplModeBit::update(flags(), value));
}
ScriptOriginOptions Script::origin_options() {
return ScriptOriginOptions(OriginOptionsBits::decode(flags()));
}
void Script::set_origin_options(ScriptOriginOptions origin_options) {
DCHECK(!(origin_options.Flags() & ~((1 << OriginOptionsBits::kSize) - 1)));
set_flags(OriginOptionsBits::update(flags(), origin_options.Flags()));
}
bool Script::HasValidSource() {
Tagged<Object> src = this->source();
if (!IsString(src)) return true;
Tagged<String> src_str = Tagged<String>::cast(src);
if (!StringShape(src_str).IsExternal()) return true;
if (src_str->IsOneByteRepresentation()) {
return ExternalOneByteString::cast(src)->resource() != nullptr;
} else if (src_str->IsTwoByteRepresentation()) {
return ExternalTwoByteString::cast(src)->resource() != nullptr;
}
return true;
}
bool Script::has_line_ends() const { return line_ends() != Smi::zero(); }
bool Script::CanHaveLineEnds() const {
#if V8_ENABLE_WEBASSEMBLY
return type() != Script::Type::kWasm;
#else
return true;
#endif // V8_ENABLE_WEBASSEMBLY
}
// static
void Script::InitLineEnds(Isolate* isolate, Handle<Script> script) {
if (script->has_line_ends()) return;
Script::InitLineEndsInternal(isolate, script);
}
// static
void Script::InitLineEnds(LocalIsolate* isolate, Handle<Script> script) {
if (script->has_line_ends()) return;
Script::InitLineEndsInternal(isolate, script);
}
bool Script::HasSourceURLComment() const {
return IsString(source_url()) && String::cast(source_url())->length() != 0;
}
bool Script::IsMaybeUnfinalized(Isolate* isolate) const {
// TODO(v8:12051): A more robust detection, e.g. with a dedicated sentinel
// value.
return IsUndefined(source(), isolate) ||
String::cast(source())->length() == 0;
}
} // namespace internal
} // namespace v8
#include "src/objects/object-macros-undef.h"
#endif // V8_OBJECTS_SCRIPT_INL_H_