Commit 5f8c2b1f authored by machenbach's avatar machenbach Committed by Commit bot

Revert of [api] Don't go to javascript to construct API functions (patchset #3...

Revert of [api] Don't go to javascript to construct API functions (patchset #3 id:40001 of https://codereview.chromium.org/1756433002/ )

Reason for revert:
[Sheriff] Breaks webkit unittests:
https://build.chromium.org/p/client.v8.fyi/builders/V8-Blink%20Linux%2064/builds/5043

Original issue's description:
> [api] Don't go to javascript to construct API functions
>
> BUG=
> R=bmeurer@chromium.org,verwaest@chromium.org
>
> Committed: https://crrev.com/21a5bfbd2ced6e4a3545bbde712630c0d8734c0b
> Cr-Commit-Position: refs/heads/master@{#34411}

TBR=bmeurer@chromium.org,verwaest@chromium.org,jochen@chromium.org
# Skipping CQ checks because original CL landed less than 1 days ago.
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=

Review URL: https://codereview.chromium.org/1758623002

Cr-Commit-Position: refs/heads/master@{#34419}
parent a3bd39e7
...@@ -4153,8 +4153,7 @@ class RelocatableArguments ...@@ -4153,8 +4153,7 @@ class RelocatableArguments
} // namespace } // namespace
MaybeHandle<Object> Builtins::InvokeApiFunction(bool is_construct, MaybeHandle<Object> Builtins::InvokeApiFunction(Handle<HeapObject> function,
Handle<HeapObject> function,
Handle<Object> receiver, Handle<Object> receiver,
int argc, int argc,
Handle<Object> args[]) { Handle<Object> args[]) {
...@@ -4176,8 +4175,7 @@ MaybeHandle<Object> Builtins::InvokeApiFunction(bool is_construct, ...@@ -4176,8 +4175,7 @@ MaybeHandle<Object> Builtins::InvokeApiFunction(bool is_construct,
{ {
auto isolate = function->GetIsolate(); auto isolate = function->GetIsolate();
RelocatableArguments arguments(isolate, argc + 2, &argv[argc + 1]); RelocatableArguments arguments(isolate, argc + 2, &argv[argc + 1]);
result = is_construct ? HandleApiCallHelper<true>(isolate, arguments) result = HandleApiCallHelper<false>(isolate, arguments);
: HandleApiCallHelper<false>(isolate, arguments);
} }
if (argv != small_argv) { if (argv != small_argv) {
delete[] argv; delete[] argv;
......
...@@ -398,8 +398,8 @@ class Builtins { ...@@ -398,8 +398,8 @@ class Builtins {
bool is_initialized() const { return initialized_; } bool is_initialized() const { return initialized_; }
MUST_USE_RESULT static MaybeHandle<Object> InvokeApiFunction( MUST_USE_RESULT static MaybeHandle<Object> InvokeApiFunction(
bool is_construct, Handle<HeapObject> function, Handle<Object> receiver, Handle<HeapObject> function, Handle<Object> receiver, int argc,
int argc, Handle<Object> args[]); Handle<Object> args[]);
private: private:
Builtins(); Builtins();
......
...@@ -59,45 +59,6 @@ MUST_USE_RESULT MaybeHandle<Object> Invoke(Isolate* isolate, bool is_construct, ...@@ -59,45 +59,6 @@ MUST_USE_RESULT MaybeHandle<Object> Invoke(Isolate* isolate, bool is_construct,
Handle<Object> new_target) { Handle<Object> new_target) {
DCHECK(!receiver->IsJSGlobalObject()); DCHECK(!receiver->IsJSGlobalObject());
// API callbacks can be called directly.
if (target->IsJSFunction() &&
Handle<JSFunction>::cast(target)->shared()->IsApiFunction()) {
Handle<JSFunction> function = Handle<JSFunction>::cast(target);
if (!function->IsConstructor()) {
THROW_NEW_ERROR(isolate,
NewTypeError(MessageTemplate::kNotConstructor, function),
Object);
}
SaveContext save(isolate);
isolate->set_context(function->context());
// Do proper receiver conversion for non-strict mode api functions.
if (!receiver->IsJSReceiver() &&
is_sloppy(function->shared()->language_mode())) {
if (receiver->IsUndefined() || receiver->IsNull()) {
if (is_construct) {
receiver = isolate->factory()->the_hole_value();
} else {
receiver = handle(function->global_proxy(), isolate);
}
} else {
ASSIGN_RETURN_ON_EXCEPTION(isolate, receiver,
Object::ToObject(isolate, receiver), Object);
}
}
DCHECK(function->context()->global_object()->IsJSGlobalObject());
auto value = Builtins::InvokeApiFunction(is_construct, function, receiver,
argc, args);
bool has_exception = value.is_null();
DCHECK(has_exception == isolate->has_pending_exception());
if (has_exception) {
isolate->ReportPendingMessages();
return MaybeHandle<Object>();
} else {
isolate->clear_pending_message();
}
return value;
}
// Entering JavaScript. // Entering JavaScript.
VMState<JS> state(isolate); VMState<JS> state(isolate);
CHECK(AllowJavascriptExecution::IsAllowed(isolate)); CHECK(AllowJavascriptExecution::IsAllowed(isolate));
...@@ -170,6 +131,35 @@ MaybeHandle<Object> Execution::Call(Isolate* isolate, Handle<Object> callable, ...@@ -170,6 +131,35 @@ MaybeHandle<Object> Execution::Call(Isolate* isolate, Handle<Object> callable,
receiver = receiver =
handle(Handle<JSGlobalObject>::cast(receiver)->global_proxy(), isolate); handle(Handle<JSGlobalObject>::cast(receiver)->global_proxy(), isolate);
} }
// api callbacks can be called directly.
if (callable->IsJSFunction() &&
Handle<JSFunction>::cast(callable)->shared()->IsApiFunction()) {
Handle<JSFunction> function = Handle<JSFunction>::cast(callable);
SaveContext save(isolate);
isolate->set_context(function->context());
// Do proper receiver conversion for non-strict mode api functions.
if (!receiver->IsJSReceiver() &&
is_sloppy(function->shared()->language_mode())) {
if (receiver->IsUndefined() || receiver->IsNull()) {
receiver = handle(function->global_proxy(), isolate);
} else {
ASSIGN_RETURN_ON_EXCEPTION(isolate, receiver,
Object::ToObject(isolate, receiver), Object);
}
}
DCHECK(function->context()->global_object()->IsJSGlobalObject());
auto value = Builtins::InvokeApiFunction(function, receiver, argc, argv);
bool has_exception = value.is_null();
DCHECK(has_exception == isolate->has_pending_exception());
if (has_exception) {
isolate->ReportPendingMessages();
return MaybeHandle<Object>();
} else {
isolate->clear_pending_message();
}
return value;
}
return Invoke(isolate, false, callable, receiver, argc, argv, return Invoke(isolate, false, callable, receiver, argc, argv,
isolate->factory()->undefined_value()); isolate->factory()->undefined_value());
} }
......
...@@ -1081,8 +1081,7 @@ MaybeHandle<Object> Object::GetPropertyWithAccessor(LookupIterator* it) { ...@@ -1081,8 +1081,7 @@ MaybeHandle<Object> Object::GetPropertyWithAccessor(LookupIterator* it) {
Handle<Object> getter(AccessorPair::cast(*structure)->getter(), isolate); Handle<Object> getter(AccessorPair::cast(*structure)->getter(), isolate);
if (getter->IsFunctionTemplateInfo()) { if (getter->IsFunctionTemplateInfo()) {
auto result = Builtins::InvokeApiFunction( auto result = Builtins::InvokeApiFunction(
false, Handle<FunctionTemplateInfo>::cast(getter), receiver, 0, Handle<FunctionTemplateInfo>::cast(getter), receiver, 0, nullptr);
nullptr);
if (isolate->has_pending_exception()) { if (isolate->has_pending_exception()) {
return MaybeHandle<Object>(); return MaybeHandle<Object>();
} }
...@@ -1151,9 +1150,9 @@ Maybe<bool> Object::SetPropertyWithAccessor(LookupIterator* it, ...@@ -1151,9 +1150,9 @@ Maybe<bool> Object::SetPropertyWithAccessor(LookupIterator* it,
Handle<Object> setter(AccessorPair::cast(*structure)->setter(), isolate); Handle<Object> setter(AccessorPair::cast(*structure)->setter(), isolate);
if (setter->IsFunctionTemplateInfo()) { if (setter->IsFunctionTemplateInfo()) {
Handle<Object> argv[] = {value}; Handle<Object> argv[] = {value};
auto result = Builtins::InvokeApiFunction( auto result =
false, Handle<FunctionTemplateInfo>::cast(setter), receiver, Builtins::InvokeApiFunction(Handle<FunctionTemplateInfo>::cast(setter),
arraysize(argv), argv); receiver, arraysize(argv), argv);
if (isolate->has_pending_exception()) { if (isolate->has_pending_exception()) {
return Nothing<bool>(); return Nothing<bool>();
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment