[api] Deprecate v8::ScriptCompiler::CompileFunctionInContext
- Introduce v8::ScriptCompiler::CompileFunction - Deprecate v8::ScriptCompiler::CompileFunctionInContext - Add v8::Function::GetUnboundScript - Add v8::Script::GetResourceName The ScriptOrModule out-parameter is only used by NodeJS since we don't allow arbitrary objects has host-defined options and they need a way to keep the options alive. This CL deprecates the out-parameter and adds helper methods to address the most common use-cases. The final fix still requires more fundamental changes on how host-defined options are handled. Bug: chromium:1244145 Change-Id: Id29de53521ad626c41391b8300146ee37a1b8a51 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3245117 Reviewed-by: Victor Gomes <victorgomes@chromium.org> Reviewed-by: Jakob Gruber <jgruber@chromium.org> Commit-Queue: Jakob Gruber <jgruber@chromium.org> Auto-Submit: Camillo Bruni <cbruni@chromium.org> Cr-Commit-Position: refs/heads/main@{#77564}
This commit is contained in:
parent
91475f958a
commit
78387ca75d
@ -18,6 +18,7 @@
|
|||||||
namespace v8 {
|
namespace v8 {
|
||||||
|
|
||||||
class Context;
|
class Context;
|
||||||
|
class UnboundScript;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A JavaScript function object (ECMA-262, 15.3).
|
* A JavaScript function object (ECMA-262, 15.3).
|
||||||
@ -58,6 +59,8 @@ class V8_EXPORT Function : public Object {
|
|||||||
void SetName(Local<String> name);
|
void SetName(Local<String> name);
|
||||||
Local<Value> GetName() const;
|
Local<Value> GetName() const;
|
||||||
|
|
||||||
|
MaybeLocal<UnboundScript> GetUnboundScript() const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Name inferred from variable or property assignment of this function.
|
* Name inferred from variable or property assignment of this function.
|
||||||
* Used to facilitate debugging and profiling of JavaScript code written
|
* Used to facilitate debugging and profiling of JavaScript code written
|
||||||
|
@ -345,6 +345,12 @@ class V8_EXPORT Script {
|
|||||||
* Returns the corresponding context-unbound script.
|
* Returns the corresponding context-unbound script.
|
||||||
*/
|
*/
|
||||||
Local<UnboundScript> GetUnboundScript();
|
Local<UnboundScript> GetUnboundScript();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The name that was passed by the embedder as ResourceName to the
|
||||||
|
* ScriptOrigin. This can be either a v8::String or v8::Undefined.
|
||||||
|
*/
|
||||||
|
Local<Value> GetResourceName();
|
||||||
};
|
};
|
||||||
|
|
||||||
enum class ScriptType { kClassic, kModule };
|
enum class ScriptType { kClassic, kModule };
|
||||||
@ -682,6 +688,7 @@ class V8_EXPORT ScriptCompiler {
|
|||||||
* It is possible to specify multiple context extensions (obj in the above
|
* It is possible to specify multiple context extensions (obj in the above
|
||||||
* example).
|
* example).
|
||||||
*/
|
*/
|
||||||
|
V8_DEPRECATE_SOON("Use CompileFunction")
|
||||||
static V8_WARN_UNUSED_RESULT MaybeLocal<Function> CompileFunctionInContext(
|
static V8_WARN_UNUSED_RESULT MaybeLocal<Function> CompileFunctionInContext(
|
||||||
Local<Context> context, Source* source, size_t arguments_count,
|
Local<Context> context, Source* source, size_t arguments_count,
|
||||||
Local<String> arguments[], size_t context_extension_count,
|
Local<String> arguments[], size_t context_extension_count,
|
||||||
@ -689,6 +696,12 @@ class V8_EXPORT ScriptCompiler {
|
|||||||
CompileOptions options = kNoCompileOptions,
|
CompileOptions options = kNoCompileOptions,
|
||||||
NoCacheReason no_cache_reason = kNoCacheNoReason,
|
NoCacheReason no_cache_reason = kNoCacheNoReason,
|
||||||
Local<ScriptOrModule>* script_or_module_out = nullptr);
|
Local<ScriptOrModule>* script_or_module_out = nullptr);
|
||||||
|
static V8_WARN_UNUSED_RESULT MaybeLocal<Function> CompileFunction(
|
||||||
|
Local<Context> context, Source* source, size_t arguments_count = 0,
|
||||||
|
Local<String> arguments[] = nullptr, size_t context_extension_count = 0,
|
||||||
|
Local<Object> context_extensions[] = nullptr,
|
||||||
|
CompileOptions options = kNoCompileOptions,
|
||||||
|
NoCacheReason no_cache_reason = kNoCacheNoReason);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates and returns code cache for the specified unbound_script.
|
* Creates and returns code cache for the specified unbound_script.
|
||||||
@ -707,7 +720,7 @@ class V8_EXPORT ScriptCompiler {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates and returns code cache for the specified function that was
|
* Creates and returns code cache for the specified function that was
|
||||||
* previously produced by CompileFunctionInContext.
|
* previously produced by CompileFunction.
|
||||||
* This will return nullptr if the script cannot be serialized. The
|
* This will return nullptr if the script cannot be serialized. The
|
||||||
* CachedData returned by this function should be owned by the caller.
|
* CachedData returned by this function should be owned by the caller.
|
||||||
*/
|
*/
|
||||||
@ -717,6 +730,13 @@ class V8_EXPORT ScriptCompiler {
|
|||||||
static V8_WARN_UNUSED_RESULT MaybeLocal<UnboundScript> CompileUnboundInternal(
|
static V8_WARN_UNUSED_RESULT MaybeLocal<UnboundScript> CompileUnboundInternal(
|
||||||
Isolate* isolate, Source* source, CompileOptions options,
|
Isolate* isolate, Source* source, CompileOptions options,
|
||||||
NoCacheReason no_cache_reason);
|
NoCacheReason no_cache_reason);
|
||||||
|
|
||||||
|
static V8_WARN_UNUSED_RESULT MaybeLocal<Function> CompileFunctionInternal(
|
||||||
|
Local<Context> context, Source* source, size_t arguments_count,
|
||||||
|
Local<String> arguments[], size_t context_extension_count,
|
||||||
|
Local<Object> context_extensions[], CompileOptions options,
|
||||||
|
NoCacheReason no_cache_reason,
|
||||||
|
Local<ScriptOrModule>* script_or_module_out);
|
||||||
};
|
};
|
||||||
|
|
||||||
ScriptCompiler::Source::Source(Local<String> string, const ScriptOrigin& origin,
|
ScriptCompiler::Source::Source(Local<String> string, const ScriptOrigin& origin,
|
||||||
|
@ -2127,12 +2127,23 @@ Local<PrimitiveArray> ScriptOrModule::GetHostDefinedOptions() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Local<UnboundScript> Script::GetUnboundScript() {
|
Local<UnboundScript> Script::GetUnboundScript() {
|
||||||
i::Handle<i::Object> obj = Utils::OpenHandle(this);
|
i::DisallowGarbageCollection no_gc;
|
||||||
i::SharedFunctionInfo sfi = i::JSFunction::cast(*obj).shared();
|
i::Handle<i::JSFunction> obj = Utils::OpenHandle(this);
|
||||||
|
i::SharedFunctionInfo sfi = (*obj).shared();
|
||||||
i::Isolate* isolate = sfi.GetIsolate();
|
i::Isolate* isolate = sfi.GetIsolate();
|
||||||
return ToApiHandle<UnboundScript>(i::handle(sfi, isolate));
|
return ToApiHandle<UnboundScript>(i::handle(sfi, isolate));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Local<Value> Script::GetResourceName() {
|
||||||
|
i::DisallowGarbageCollection no_gc;
|
||||||
|
i::Handle<i::JSFunction> func = Utils::OpenHandle(this);
|
||||||
|
i::SharedFunctionInfo sfi = (*func).shared();
|
||||||
|
i::Isolate* isolate = func->GetIsolate();
|
||||||
|
CHECK(sfi.script().IsScript());
|
||||||
|
return ToApiHandle<Value>(
|
||||||
|
i::handle(i::Script::cast(sfi.script()).name(), isolate));
|
||||||
|
}
|
||||||
|
|
||||||
// static
|
// static
|
||||||
Local<PrimitiveArray> PrimitiveArray::New(Isolate* v8_isolate, int length) {
|
Local<PrimitiveArray> PrimitiveArray::New(Isolate* v8_isolate, int length) {
|
||||||
i::Isolate* isolate = reinterpret_cast<i::Isolate*>(v8_isolate);
|
i::Isolate* isolate = reinterpret_cast<i::Isolate*>(v8_isolate);
|
||||||
@ -2594,9 +2605,32 @@ bool IsIdentifier(i::Isolate* isolate, i::Handle<i::String> string) {
|
|||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
} // anonymous namespace
|
} // namespace
|
||||||
|
|
||||||
|
// static
|
||||||
|
V8_WARN_UNUSED_RESULT MaybeLocal<Function> ScriptCompiler::CompileFunction(
|
||||||
|
Local<Context> context, Source* source, size_t arguments_count,
|
||||||
|
Local<String> arguments[], size_t context_extension_count,
|
||||||
|
Local<Object> context_extensions[], CompileOptions options,
|
||||||
|
NoCacheReason no_cache_reason) {
|
||||||
|
return CompileFunctionInternal(context, source, arguments_count, arguments,
|
||||||
|
context_extension_count, context_extensions,
|
||||||
|
options, no_cache_reason, nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
// static
|
||||||
MaybeLocal<Function> ScriptCompiler::CompileFunctionInContext(
|
MaybeLocal<Function> ScriptCompiler::CompileFunctionInContext(
|
||||||
|
Local<Context> context, Source* source, size_t arguments_count,
|
||||||
|
Local<String> arguments[], size_t context_extension_count,
|
||||||
|
Local<Object> context_extensions[], CompileOptions options,
|
||||||
|
NoCacheReason no_cache_reason,
|
||||||
|
Local<ScriptOrModule>* script_or_module_out) {
|
||||||
|
return CompileFunctionInternal(
|
||||||
|
context, source, arguments_count, arguments, context_extension_count,
|
||||||
|
context_extensions, options, no_cache_reason, script_or_module_out);
|
||||||
|
}
|
||||||
|
|
||||||
|
MaybeLocal<Function> ScriptCompiler::CompileFunctionInternal(
|
||||||
Local<Context> v8_context, Source* source, size_t arguments_count,
|
Local<Context> v8_context, Source* source, size_t arguments_count,
|
||||||
Local<String> arguments[], size_t context_extension_count,
|
Local<String> arguments[], size_t context_extension_count,
|
||||||
Local<Object> context_extensions[], CompileOptions options,
|
Local<Object> context_extensions[], CompileOptions options,
|
||||||
@ -2605,7 +2639,7 @@ MaybeLocal<Function> ScriptCompiler::CompileFunctionInContext(
|
|||||||
Local<Function> result;
|
Local<Function> result;
|
||||||
|
|
||||||
{
|
{
|
||||||
PREPARE_FOR_EXECUTION(v8_context, ScriptCompiler, CompileFunctionInContext,
|
PREPARE_FOR_EXECUTION(v8_context, ScriptCompiler, CompileFunction,
|
||||||
Function);
|
Function);
|
||||||
TRACE_EVENT_CALL_STATS_SCOPED(isolate, "v8", "V8.ScriptCompiler");
|
TRACE_EVENT_CALL_STATS_SCOPED(isolate, "v8", "V8.ScriptCompiler");
|
||||||
|
|
||||||
@ -5288,6 +5322,14 @@ int Function::GetScriptColumnNumber() const {
|
|||||||
return kLineOffsetNotFound;
|
return kLineOffsetNotFound;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
MaybeLocal<UnboundScript> Function::GetUnboundScript() const {
|
||||||
|
i::Handle<i::Object> self = Utils::OpenHandle(this);
|
||||||
|
if (!self->IsJSFunction()) return MaybeLocal<UnboundScript>();
|
||||||
|
i::SharedFunctionInfo sfi = i::JSFunction::cast(*self).shared();
|
||||||
|
i::Isolate* isolate = sfi.GetIsolate();
|
||||||
|
return ToApiHandle<UnboundScript>(i::handle(sfi, isolate));
|
||||||
|
}
|
||||||
|
|
||||||
int Function::ScriptId() const {
|
int Function::ScriptId() const {
|
||||||
i::JSReceiver self = *Utils::OpenHandle(this);
|
i::JSReceiver self = *Utils::OpenHandle(this);
|
||||||
if (!self.IsJSFunction()) return v8::UnboundScript::kNoScriptId;
|
if (!self.IsJSFunction()) return v8::UnboundScript::kNoScriptId;
|
||||||
|
@ -2160,7 +2160,7 @@ namespace {
|
|||||||
debug::Location GetDebugLocation(Handle<Script> script, int source_position) {
|
debug::Location GetDebugLocation(Handle<Script> script, int source_position) {
|
||||||
Script::PositionInfo info;
|
Script::PositionInfo info;
|
||||||
Script::GetPositionInfo(script, source_position, &info, Script::WITH_OFFSET);
|
Script::GetPositionInfo(script, source_position, &info, Script::WITH_OFFSET);
|
||||||
// V8 provides ScriptCompiler::CompileFunctionInContext method which takes
|
// V8 provides ScriptCompiler::CompileFunction method which takes
|
||||||
// expression and compile it as anonymous function like (function() ..
|
// expression and compile it as anonymous function like (function() ..
|
||||||
// expression ..). To produce correct locations for stmts inside of this
|
// expression ..). To produce correct locations for stmts inside of this
|
||||||
// expression V8 compile this function with negative offset. Instead of stmt
|
// expression V8 compile this function with negative offset. Instead of stmt
|
||||||
|
@ -245,7 +245,7 @@ class RuntimeCallTimer final {
|
|||||||
V(RegExp_Exec) \
|
V(RegExp_Exec) \
|
||||||
V(RegExp_New) \
|
V(RegExp_New) \
|
||||||
V(ScriptCompiler_Compile) \
|
V(ScriptCompiler_Compile) \
|
||||||
V(ScriptCompiler_CompileFunctionInContext) \
|
V(ScriptCompiler_CompileFunction) \
|
||||||
V(ScriptCompiler_CompileUnbound) \
|
V(ScriptCompiler_CompileUnbound) \
|
||||||
V(Script_Run) \
|
V(Script_Run) \
|
||||||
V(Set_Add) \
|
V(Set_Add) \
|
||||||
|
@ -441,7 +441,7 @@ TEST(OptimizedCodeSharing1) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(CompileFunctionInContext) {
|
TEST(CompileFunction) {
|
||||||
if (i::FLAG_always_opt) return;
|
if (i::FLAG_always_opt) return;
|
||||||
CcTest::InitializeVM();
|
CcTest::InitializeVM();
|
||||||
v8::HandleScope scope(CcTest::isolate());
|
v8::HandleScope scope(CcTest::isolate());
|
||||||
@ -454,8 +454,8 @@ TEST(CompileFunctionInContext) {
|
|||||||
"x = r * cos(PI);"
|
"x = r * cos(PI);"
|
||||||
"y = r * sin(PI / 2);"));
|
"y = r * sin(PI / 2);"));
|
||||||
v8::Local<v8::Function> fun =
|
v8::Local<v8::Function> fun =
|
||||||
v8::ScriptCompiler::CompileFunctionInContext(env.local(), &script_source,
|
v8::ScriptCompiler::CompileFunction(env.local(), &script_source, 0,
|
||||||
0, nullptr, 1, &math)
|
nullptr, 1, &math)
|
||||||
.ToLocalChecked();
|
.ToLocalChecked();
|
||||||
CHECK(!fun.IsEmpty());
|
CHECK(!fun.IsEmpty());
|
||||||
|
|
||||||
@ -478,8 +478,7 @@ TEST(CompileFunctionInContext) {
|
|||||||
CHECK_EQ(10.0, y->NumberValue(env.local()).FromJust());
|
CHECK_EQ(10.0, y->NumberValue(env.local()).FromJust());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST(CompileFunctionComplex) {
|
||||||
TEST(CompileFunctionInContextComplex) {
|
|
||||||
CcTest::InitializeVM();
|
CcTest::InitializeVM();
|
||||||
v8::HandleScope scope(CcTest::isolate());
|
v8::HandleScope scope(CcTest::isolate());
|
||||||
LocalContext env;
|
LocalContext env;
|
||||||
@ -496,8 +495,8 @@ TEST(CompileFunctionInContextComplex) {
|
|||||||
env->Global()->Get(env.local(), v8_str("b")).ToLocalChecked());
|
env->Global()->Get(env.local(), v8_str("b")).ToLocalChecked());
|
||||||
v8::ScriptCompiler::Source script_source(v8_str("result = x + y + z"));
|
v8::ScriptCompiler::Source script_source(v8_str("result = x + y + z"));
|
||||||
v8::Local<v8::Function> fun =
|
v8::Local<v8::Function> fun =
|
||||||
v8::ScriptCompiler::CompileFunctionInContext(env.local(), &script_source,
|
v8::ScriptCompiler::CompileFunction(env.local(), &script_source, 0,
|
||||||
0, nullptr, 2, ext)
|
nullptr, 2, ext)
|
||||||
.ToLocalChecked();
|
.ToLocalChecked();
|
||||||
CHECK(!fun.IsEmpty());
|
CHECK(!fun.IsEmpty());
|
||||||
fun->Call(env.local(), env->Global(), 0, nullptr).ToLocalChecked();
|
fun->Call(env.local(), env->Global(), 0, nullptr).ToLocalChecked();
|
||||||
@ -508,8 +507,7 @@ TEST(CompileFunctionInContextComplex) {
|
|||||||
CHECK_EQ(52.0, result->NumberValue(env.local()).FromJust());
|
CHECK_EQ(52.0, result->NumberValue(env.local()).FromJust());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST(CompileFunctionArgs) {
|
||||||
TEST(CompileFunctionInContextArgs) {
|
|
||||||
CcTest::InitializeVM();
|
CcTest::InitializeVM();
|
||||||
v8::HandleScope scope(CcTest::isolate());
|
v8::HandleScope scope(CcTest::isolate());
|
||||||
LocalContext env;
|
LocalContext env;
|
||||||
@ -520,8 +518,8 @@ TEST(CompileFunctionInContextArgs) {
|
|||||||
v8::ScriptCompiler::Source script_source(v8_str("result = x + abc"));
|
v8::ScriptCompiler::Source script_source(v8_str("result = x + abc"));
|
||||||
v8::Local<v8::String> arg = v8_str("abc");
|
v8::Local<v8::String> arg = v8_str("abc");
|
||||||
v8::Local<v8::Function> fun =
|
v8::Local<v8::Function> fun =
|
||||||
v8::ScriptCompiler::CompileFunctionInContext(env.local(), &script_source,
|
v8::ScriptCompiler::CompileFunction(env.local(), &script_source, 1, &arg,
|
||||||
1, &arg, 1, ext)
|
1, ext)
|
||||||
.ToLocalChecked();
|
.ToLocalChecked();
|
||||||
CHECK_EQ(1, fun->Get(env.local(), v8_str("length"))
|
CHECK_EQ(1, fun->Get(env.local(), v8_str("length"))
|
||||||
.ToLocalChecked()
|
.ToLocalChecked()
|
||||||
@ -537,8 +535,7 @@ TEST(CompileFunctionInContextArgs) {
|
|||||||
CHECK_EQ(65.0, result->NumberValue(env.local()).FromJust());
|
CHECK_EQ(65.0, result->NumberValue(env.local()).FromJust());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST(CompileFunctionComments) {
|
||||||
TEST(CompileFunctionInContextComments) {
|
|
||||||
CcTest::InitializeVM();
|
CcTest::InitializeVM();
|
||||||
v8::HandleScope scope(CcTest::isolate());
|
v8::HandleScope scope(CcTest::isolate());
|
||||||
LocalContext env;
|
LocalContext env;
|
||||||
@ -551,8 +548,8 @@ TEST(CompileFunctionInContextComments) {
|
|||||||
v8::ScriptCompiler::Source script_source(source);
|
v8::ScriptCompiler::Source script_source(source);
|
||||||
v8::Local<v8::String> arg = CompileRun("'a\\u4e00'").As<v8::String>();
|
v8::Local<v8::String> arg = CompileRun("'a\\u4e00'").As<v8::String>();
|
||||||
v8::Local<v8::Function> fun =
|
v8::Local<v8::Function> fun =
|
||||||
v8::ScriptCompiler::CompileFunctionInContext(env.local(), &script_source,
|
v8::ScriptCompiler::CompileFunction(env.local(), &script_source, 1, &arg,
|
||||||
1, &arg, 1, ext)
|
1, ext)
|
||||||
.ToLocalChecked();
|
.ToLocalChecked();
|
||||||
CHECK(!fun.IsEmpty());
|
CHECK(!fun.IsEmpty());
|
||||||
v8::Local<v8::Value> arg_value = v8::Number::New(CcTest::isolate(), 42.0);
|
v8::Local<v8::Value> arg_value = v8::Number::New(CcTest::isolate(), 42.0);
|
||||||
@ -564,19 +561,18 @@ TEST(CompileFunctionInContextComments) {
|
|||||||
CHECK_EQ(65.0, result->NumberValue(env.local()).FromJust());
|
CHECK_EQ(65.0, result->NumberValue(env.local()).FromJust());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST(CompileFunctionNonIdentifierArgs) {
|
||||||
TEST(CompileFunctionInContextNonIdentifierArgs) {
|
|
||||||
CcTest::InitializeVM();
|
CcTest::InitializeVM();
|
||||||
v8::HandleScope scope(CcTest::isolate());
|
v8::HandleScope scope(CcTest::isolate());
|
||||||
LocalContext env;
|
LocalContext env;
|
||||||
v8::ScriptCompiler::Source script_source(v8_str("result = 1"));
|
v8::ScriptCompiler::Source script_source(v8_str("result = 1"));
|
||||||
v8::Local<v8::String> arg = v8_str("b }");
|
v8::Local<v8::String> arg = v8_str("b }");
|
||||||
CHECK(v8::ScriptCompiler::CompileFunctionInContext(
|
CHECK(
|
||||||
env.local(), &script_source, 1, &arg, 0, nullptr)
|
v8::ScriptCompiler::CompileFunction(env.local(), &script_source, 1, &arg)
|
||||||
.IsEmpty());
|
.IsEmpty());
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(CompileFunctionInContextRenderCallSite) {
|
TEST(CompileFunctionRenderCallSite) {
|
||||||
CcTest::InitializeVM();
|
CcTest::InitializeVM();
|
||||||
v8::HandleScope scope(CcTest::isolate());
|
v8::HandleScope scope(CcTest::isolate());
|
||||||
LocalContext env;
|
LocalContext env;
|
||||||
@ -601,8 +597,7 @@ TEST(CompileFunctionInContextRenderCallSite) {
|
|||||||
{
|
{
|
||||||
v8::ScriptCompiler::Source script_source(v8_str(source1));
|
v8::ScriptCompiler::Source script_source(v8_str(source1));
|
||||||
v8::Local<v8::Function> fun =
|
v8::Local<v8::Function> fun =
|
||||||
v8::ScriptCompiler::CompileFunctionInContext(
|
v8::ScriptCompiler::CompileFunction(env.local(), &script_source)
|
||||||
env.local(), &script_source, 0, nullptr, 0, nullptr)
|
|
||||||
.ToLocalChecked();
|
.ToLocalChecked();
|
||||||
CHECK(!fun.IsEmpty());
|
CHECK(!fun.IsEmpty());
|
||||||
v8::Local<v8::Value> result =
|
v8::Local<v8::Value> result =
|
||||||
@ -615,8 +610,7 @@ TEST(CompileFunctionInContextRenderCallSite) {
|
|||||||
{
|
{
|
||||||
v8::ScriptCompiler::Source script_source(v8_str(source2));
|
v8::ScriptCompiler::Source script_source(v8_str(source2));
|
||||||
v8::Local<v8::Function> fun =
|
v8::Local<v8::Function> fun =
|
||||||
v8::ScriptCompiler::CompileFunctionInContext(
|
v8::ScriptCompiler::CompileFunction(env.local(), &script_source)
|
||||||
env.local(), &script_source, 0, nullptr, 0, nullptr)
|
|
||||||
.ToLocalChecked();
|
.ToLocalChecked();
|
||||||
v8::Local<v8::Value> result =
|
v8::Local<v8::Value> result =
|
||||||
fun->Call(env.local(), env->Global(), 0, nullptr).ToLocalChecked();
|
fun->Call(env.local(), env->Global(), 0, nullptr).ToLocalChecked();
|
||||||
@ -627,7 +621,7 @@ TEST(CompileFunctionInContextRenderCallSite) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(CompileFunctionInContextQuirks) {
|
TEST(CompileFunctionQuirks) {
|
||||||
CcTest::InitializeVM();
|
CcTest::InitializeVM();
|
||||||
v8::HandleScope scope(CcTest::isolate());
|
v8::HandleScope scope(CcTest::isolate());
|
||||||
LocalContext env;
|
LocalContext env;
|
||||||
@ -638,8 +632,7 @@ TEST(CompileFunctionInContextQuirks) {
|
|||||||
static const char* expect = "abcd";
|
static const char* expect = "abcd";
|
||||||
v8::ScriptCompiler::Source script_source(v8_str(source));
|
v8::ScriptCompiler::Source script_source(v8_str(source));
|
||||||
v8::Local<v8::Function> fun =
|
v8::Local<v8::Function> fun =
|
||||||
v8::ScriptCompiler::CompileFunctionInContext(
|
v8::ScriptCompiler::CompileFunction(env.local(), &script_source)
|
||||||
env.local(), &script_source, 0, nullptr, 0, nullptr)
|
|
||||||
.ToLocalChecked();
|
.ToLocalChecked();
|
||||||
v8::Local<v8::Value> result =
|
v8::Local<v8::Value> result =
|
||||||
fun->Call(env.local(), env->Global(), 0, nullptr).ToLocalChecked();
|
fun->Call(env.local(), env->Global(), 0, nullptr).ToLocalChecked();
|
||||||
@ -652,8 +645,7 @@ TEST(CompileFunctionInContextQuirks) {
|
|||||||
static const char* source = "'use strict'; var a = 077";
|
static const char* source = "'use strict'; var a = 077";
|
||||||
v8::ScriptCompiler::Source script_source(v8_str(source));
|
v8::ScriptCompiler::Source script_source(v8_str(source));
|
||||||
v8::TryCatch try_catch(CcTest::isolate());
|
v8::TryCatch try_catch(CcTest::isolate());
|
||||||
CHECK(v8::ScriptCompiler::CompileFunctionInContext(
|
CHECK(v8::ScriptCompiler::CompileFunction(env.local(), &script_source)
|
||||||
env.local(), &script_source, 0, nullptr, 0, nullptr)
|
|
||||||
.IsEmpty());
|
.IsEmpty());
|
||||||
CHECK(try_catch.HasCaught());
|
CHECK(try_catch.HasCaught());
|
||||||
}
|
}
|
||||||
@ -661,30 +653,27 @@ TEST(CompileFunctionInContextQuirks) {
|
|||||||
static const char* source = "{ let x; { var x } }";
|
static const char* source = "{ let x; { var x } }";
|
||||||
v8::ScriptCompiler::Source script_source(v8_str(source));
|
v8::ScriptCompiler::Source script_source(v8_str(source));
|
||||||
v8::TryCatch try_catch(CcTest::isolate());
|
v8::TryCatch try_catch(CcTest::isolate());
|
||||||
CHECK(v8::ScriptCompiler::CompileFunctionInContext(
|
CHECK(v8::ScriptCompiler::CompileFunction(env.local(), &script_source)
|
||||||
env.local(), &script_source, 0, nullptr, 0, nullptr)
|
|
||||||
.IsEmpty());
|
.IsEmpty());
|
||||||
CHECK(try_catch.HasCaught());
|
CHECK(try_catch.HasCaught());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(CompileFunctionInContextScriptOrigin) {
|
TEST(CompileFunctionScriptOrigin) {
|
||||||
CcTest::InitializeVM();
|
CcTest::InitializeVM();
|
||||||
v8::Isolate* isolate = CcTest::isolate();
|
v8::Isolate* isolate = CcTest::isolate();
|
||||||
v8::HandleScope scope(isolate);
|
v8::HandleScope scope(isolate);
|
||||||
LocalContext env;
|
LocalContext env;
|
||||||
v8::ScriptOrigin origin(isolate, v8_str("test"), 22, 41);
|
v8::ScriptOrigin origin(isolate, v8_str("test"), 22, 41);
|
||||||
v8::ScriptCompiler::Source script_source(v8_str("throw new Error()"), origin);
|
v8::ScriptCompiler::Source script_source(v8_str("throw new Error()"), origin);
|
||||||
Local<v8::ScriptOrModule> script;
|
|
||||||
v8::Local<v8::Function> fun =
|
v8::Local<v8::Function> fun =
|
||||||
v8::ScriptCompiler::CompileFunctionInContext(
|
v8::ScriptCompiler::CompileFunction(env.local(), &script_source)
|
||||||
env.local(), &script_source, 0, nullptr, 0, nullptr,
|
|
||||||
v8::ScriptCompiler::CompileOptions::kNoCompileOptions,
|
|
||||||
v8::ScriptCompiler::NoCacheReason::kNoCacheNoReason, &script)
|
|
||||||
.ToLocalChecked();
|
.ToLocalChecked();
|
||||||
CHECK(!fun.IsEmpty());
|
CHECK(!fun.IsEmpty());
|
||||||
|
v8::Local<v8::UnboundScript> script =
|
||||||
|
fun->GetUnboundScript().ToLocalChecked();
|
||||||
CHECK(!script.IsEmpty());
|
CHECK(!script.IsEmpty());
|
||||||
CHECK(script->GetResourceName()->StrictEquals(v8_str("test")));
|
CHECK(script->GetScriptName()->StrictEquals(v8_str("test")));
|
||||||
v8::TryCatch try_catch(CcTest::isolate());
|
v8::TryCatch try_catch(CcTest::isolate());
|
||||||
CcTest::isolate()->SetCaptureStackTraceForUncaughtExceptions(true);
|
CcTest::isolate()->SetCaptureStackTraceForUncaughtExceptions(true);
|
||||||
CHECK(fun->Call(env.local(), env->Global(), 0, nullptr).IsEmpty());
|
CHECK(fun->Call(env.local(), env->Global(), 0, nullptr).IsEmpty());
|
||||||
@ -699,7 +688,7 @@ TEST(CompileFunctionInContextScriptOrigin) {
|
|||||||
CHECK_EQ(42 + strlen("throw "), static_cast<unsigned>(frame->GetColumn()));
|
CHECK_EQ(42 + strlen("throw "), static_cast<unsigned>(frame->GetColumn()));
|
||||||
}
|
}
|
||||||
|
|
||||||
void TestCompileFunctionInContextToStringImpl() {
|
void TestCompileFunctionToStringImpl() {
|
||||||
#define CHECK_NOT_CAUGHT(__local_context__, try_catch, __op__) \
|
#define CHECK_NOT_CAUGHT(__local_context__, try_catch, __op__) \
|
||||||
do { \
|
do { \
|
||||||
const char* op = (__op__); \
|
const char* op = (__op__); \
|
||||||
@ -726,12 +715,11 @@ void TestCompileFunctionInContextToStringImpl() {
|
|||||||
v8::Local<v8::String> params[] = {v8_str("event")};
|
v8::Local<v8::String> params[] = {v8_str("event")};
|
||||||
v8::TryCatch try_catch(CcTest::isolate());
|
v8::TryCatch try_catch(CcTest::isolate());
|
||||||
v8::MaybeLocal<v8::Function> maybe_fun =
|
v8::MaybeLocal<v8::Function> maybe_fun =
|
||||||
v8::ScriptCompiler::CompileFunctionInContext(
|
v8::ScriptCompiler::CompileFunction(env.local(), &script_source,
|
||||||
env.local(), &script_source, arraysize(params), params, 0,
|
arraysize(params), params);
|
||||||
nullptr);
|
|
||||||
|
|
||||||
CHECK_NOT_CAUGHT(env.local(), try_catch,
|
CHECK_NOT_CAUGHT(env.local(), try_catch,
|
||||||
"v8::ScriptCompiler::CompileFunctionInContext");
|
"v8::ScriptCompiler::CompileFunction");
|
||||||
|
|
||||||
v8::Local<v8::Function> fun = maybe_fun.ToLocalChecked();
|
v8::Local<v8::Function> fun = maybe_fun.ToLocalChecked();
|
||||||
CHECK(!fun.IsEmpty());
|
CHECK(!fun.IsEmpty());
|
||||||
@ -752,11 +740,10 @@ void TestCompileFunctionInContextToStringImpl() {
|
|||||||
|
|
||||||
v8::TryCatch try_catch(CcTest::isolate());
|
v8::TryCatch try_catch(CcTest::isolate());
|
||||||
v8::MaybeLocal<v8::Function> maybe_fun =
|
v8::MaybeLocal<v8::Function> maybe_fun =
|
||||||
v8::ScriptCompiler::CompileFunctionInContext(
|
v8::ScriptCompiler::CompileFunction(env.local(), &script_source);
|
||||||
env.local(), &script_source, 0, nullptr, 0, nullptr);
|
|
||||||
|
|
||||||
CHECK_NOT_CAUGHT(env.local(), try_catch,
|
CHECK_NOT_CAUGHT(env.local(), try_catch,
|
||||||
"v8::ScriptCompiler::CompileFunctionInContext");
|
"v8::ScriptCompiler::CompileFunction");
|
||||||
|
|
||||||
v8::Local<v8::Function> fun = maybe_fun.ToLocalChecked();
|
v8::Local<v8::Function> fun = maybe_fun.ToLocalChecked();
|
||||||
CHECK(!fun.IsEmpty());
|
CHECK(!fun.IsEmpty());
|
||||||
@ -777,11 +764,10 @@ void TestCompileFunctionInContextToStringImpl() {
|
|||||||
|
|
||||||
v8::TryCatch try_catch(CcTest::isolate());
|
v8::TryCatch try_catch(CcTest::isolate());
|
||||||
v8::MaybeLocal<v8::Function> maybe_fun =
|
v8::MaybeLocal<v8::Function> maybe_fun =
|
||||||
v8::ScriptCompiler::CompileFunctionInContext(
|
v8::ScriptCompiler::CompileFunction(env.local(), &script_source);
|
||||||
env.local(), &script_source, 0, nullptr, 0, nullptr);
|
|
||||||
|
|
||||||
CHECK_NOT_CAUGHT(env.local(), try_catch,
|
CHECK_NOT_CAUGHT(env.local(), try_catch,
|
||||||
"v8::ScriptCompiler::CompileFunctionInContext");
|
"v8::ScriptCompiler::CompileFunction");
|
||||||
|
|
||||||
v8::Local<v8::Function> fun = maybe_fun.ToLocalChecked();
|
v8::Local<v8::Function> fun = maybe_fun.ToLocalChecked();
|
||||||
CHECK(!fun.IsEmpty());
|
CHECK(!fun.IsEmpty());
|
||||||
@ -801,9 +787,7 @@ void TestCompileFunctionInContextToStringImpl() {
|
|||||||
#undef CHECK_NOT_CAUGHT
|
#undef CHECK_NOT_CAUGHT
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(CompileFunctionInContextFunctionToString) {
|
TEST(CompileFunctionFunctionToString) { TestCompileFunctionToStringImpl(); }
|
||||||
TestCompileFunctionInContextToStringImpl();
|
|
||||||
}
|
|
||||||
|
|
||||||
TEST(InvocationCount) {
|
TEST(InvocationCount) {
|
||||||
if (FLAG_lite_mode) return;
|
if (FLAG_lite_mode) return;
|
||||||
|
@ -3038,8 +3038,7 @@ TEST(DebugBreakInWrappedScript) {
|
|||||||
{
|
{
|
||||||
v8::ScriptCompiler::Source script_source(v8_str(source));
|
v8::ScriptCompiler::Source script_source(v8_str(source));
|
||||||
v8::Local<v8::Function> fun =
|
v8::Local<v8::Function> fun =
|
||||||
v8::ScriptCompiler::CompileFunctionInContext(
|
v8::ScriptCompiler::CompileFunction(env.local(), &script_source)
|
||||||
env.local(), &script_source, 0, nullptr, 0, nullptr)
|
|
||||||
.ToLocalChecked();
|
.ToLocalChecked();
|
||||||
v8::Local<v8::Value> result =
|
v8::Local<v8::Value> result =
|
||||||
fun->Call(env.local(), env->Global(), 0, nullptr).ToLocalChecked();
|
fun->Call(env.local(), env->Global(), 0, nullptr).ToLocalChecked();
|
||||||
@ -5373,8 +5372,7 @@ TEST(TerminateOnResumeAtException) {
|
|||||||
|
|
||||||
v8::ScriptCompiler::Source script_source(v8_str(source));
|
v8::ScriptCompiler::Source script_source(v8_str(source));
|
||||||
v8::Local<v8::Function> foo =
|
v8::Local<v8::Function> foo =
|
||||||
v8::ScriptCompiler::CompileFunctionInContext(
|
v8::ScriptCompiler::CompileFunction(env.local(), &script_source)
|
||||||
env.local(), &script_source, 0, nullptr, 0, nullptr)
|
|
||||||
.ToLocalChecked();
|
.ToLocalChecked();
|
||||||
|
|
||||||
v8::MaybeLocal<v8::Value> val =
|
v8::MaybeLocal<v8::Value> val =
|
||||||
@ -5620,8 +5618,7 @@ TEST(TerminateOnResumeFromOtherThread) {
|
|||||||
|
|
||||||
v8::ScriptCompiler::Source script_source(v8_str(source));
|
v8::ScriptCompiler::Source script_source(v8_str(source));
|
||||||
v8::Local<v8::Function> foo =
|
v8::Local<v8::Function> foo =
|
||||||
v8::ScriptCompiler::CompileFunctionInContext(
|
v8::ScriptCompiler::CompileFunction(env.local(), &script_source)
|
||||||
env.local(), &script_source, 0, nullptr, 0, nullptr)
|
|
||||||
.ToLocalChecked();
|
.ToLocalChecked();
|
||||||
|
|
||||||
v8::MaybeLocal<v8::Value> val =
|
v8::MaybeLocal<v8::Value> val =
|
||||||
@ -5675,8 +5672,7 @@ TEST(TerminateOnResumeAtInterruptFromOtherThread) {
|
|||||||
|
|
||||||
v8::ScriptCompiler::Source script_source(v8_str(source));
|
v8::ScriptCompiler::Source script_source(v8_str(source));
|
||||||
v8::Local<v8::Function> foo =
|
v8::Local<v8::Function> foo =
|
||||||
v8::ScriptCompiler::CompileFunctionInContext(
|
v8::ScriptCompiler::CompileFunction(env.local(), &script_source)
|
||||||
env.local(), &script_source, 0, nullptr, 0, nullptr)
|
|
||||||
.ToLocalChecked();
|
.ToLocalChecked();
|
||||||
|
|
||||||
CHECK(timeout_thread.Start());
|
CHECK(timeout_thread.Start());
|
||||||
|
@ -633,8 +633,8 @@ UNINITIALIZED_TEST(LogInterpretedFramesNativeStackWithSerialization) {
|
|||||||
|
|
||||||
v8::ScriptCompiler::Source script_source(source, origin, cache);
|
v8::ScriptCompiler::Source script_source(source, origin, cache);
|
||||||
v8::Local<v8::Function> fun =
|
v8::Local<v8::Function> fun =
|
||||||
v8::ScriptCompiler::CompileFunctionInContext(
|
v8::ScriptCompiler::CompileFunction(context, &script_source, 1,
|
||||||
context, &script_source, 1, &arg_str, 0, nullptr, options)
|
&arg_str, 0, nullptr, options)
|
||||||
.ToLocalChecked();
|
.ToLocalChecked();
|
||||||
if (has_cache) {
|
if (has_cache) {
|
||||||
logger.StopLogging();
|
logger.StopLogging();
|
||||||
|
@ -4255,7 +4255,7 @@ TEST(WeakArraySerializationInCodeCache) {
|
|||||||
delete cache;
|
delete cache;
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(CachedCompileFunctionInContext) {
|
TEST(CachedCompileFunction) {
|
||||||
DisableAlwaysOpt();
|
DisableAlwaysOpt();
|
||||||
LocalContext env;
|
LocalContext env;
|
||||||
Isolate* isolate = CcTest::i_isolate();
|
Isolate* isolate = CcTest::i_isolate();
|
||||||
@ -4270,8 +4270,8 @@ TEST(CachedCompileFunctionInContext) {
|
|||||||
{
|
{
|
||||||
v8::ScriptCompiler::Source script_source(source);
|
v8::ScriptCompiler::Source script_source(source);
|
||||||
v8::Local<v8::Function> fun =
|
v8::Local<v8::Function> fun =
|
||||||
v8::ScriptCompiler::CompileFunctionInContext(
|
v8::ScriptCompiler::CompileFunction(env.local(), &script_source, 1,
|
||||||
env.local(), &script_source, 1, &arg_str, 0, nullptr,
|
&arg_str, 0, nullptr,
|
||||||
v8::ScriptCompiler::kEagerCompile)
|
v8::ScriptCompiler::kEagerCompile)
|
||||||
.ToLocalChecked();
|
.ToLocalChecked();
|
||||||
cache = v8::ScriptCompiler::CreateCodeCacheForFunction(fun);
|
cache = v8::ScriptCompiler::CreateCodeCacheForFunction(fun);
|
||||||
@ -4281,7 +4281,7 @@ TEST(CachedCompileFunctionInContext) {
|
|||||||
DisallowCompilation no_compile_expected(isolate);
|
DisallowCompilation no_compile_expected(isolate);
|
||||||
v8::ScriptCompiler::Source script_source(source, cache);
|
v8::ScriptCompiler::Source script_source(source, cache);
|
||||||
v8::Local<v8::Function> fun =
|
v8::Local<v8::Function> fun =
|
||||||
v8::ScriptCompiler::CompileFunctionInContext(
|
v8::ScriptCompiler::CompileFunction(
|
||||||
env.local(), &script_source, 1, &arg_str, 0, nullptr,
|
env.local(), &script_source, 1, &arg_str, 0, nullptr,
|
||||||
v8::ScriptCompiler::kConsumeCodeCache)
|
v8::ScriptCompiler::kConsumeCodeCache)
|
||||||
.ToLocalChecked();
|
.ToLocalChecked();
|
||||||
|
Loading…
Reference in New Issue
Block a user