fix: gin_helper::MicrotasksScope instantiation (#43209)
Co-authored-by: trop[bot] <37223003+trop[bot]@users.noreply.github.com> Co-authored-by: Charles Kerr <charles@charleskerr.com>
This commit is contained in:
parent
cbf1adb1b7
commit
54b31f153c
12 changed files with 55 additions and 44 deletions
|
@ -46,9 +46,9 @@ void AutoUpdater::OnError(const std::string& message) {
|
||||||
gin::StringToV8(isolate, message),
|
gin::StringToV8(isolate, message),
|
||||||
};
|
};
|
||||||
|
|
||||||
gin_helper::MicrotasksScope microtasks_scope(
|
gin_helper::MicrotasksScope microtasks_scope{
|
||||||
isolate, wrapper->GetCreationContextChecked()->GetMicrotaskQueue(),
|
isolate, wrapper->GetCreationContextChecked()->GetMicrotaskQueue(),
|
||||||
true);
|
true, v8::MicrotasksScope::kRunMicrotasks};
|
||||||
|
|
||||||
node::MakeCallback(isolate, wrapper, "emit", args.size(), args.data(),
|
node::MakeCallback(isolate, wrapper, "emit", args.size(), args.data(),
|
||||||
{0, 0});
|
{0, 0});
|
||||||
|
|
|
@ -240,8 +240,9 @@ void ElectronBindings::DidReceiveMemoryDump(
|
||||||
v8::HandleScope handle_scope(isolate);
|
v8::HandleScope handle_scope(isolate);
|
||||||
v8::Local<v8::Context> local_context =
|
v8::Local<v8::Context> local_context =
|
||||||
v8::Local<v8::Context>::New(isolate, context);
|
v8::Local<v8::Context>::New(isolate, context);
|
||||||
gin_helper::MicrotasksScope microtasks_scope(
|
gin_helper::MicrotasksScope microtasks_scope{
|
||||||
isolate, local_context->GetMicrotaskQueue(), true);
|
isolate, local_context->GetMicrotaskQueue(), true,
|
||||||
|
v8::MicrotasksScope::kRunMicrotasks};
|
||||||
v8::Context::Scope context_scope(local_context);
|
v8::Context::Scope context_scope(local_context);
|
||||||
|
|
||||||
if (!success) {
|
if (!success) {
|
||||||
|
|
|
@ -50,8 +50,9 @@ struct V8FunctionInvoker<v8::Local<v8::Value>(ArgTypes...)> {
|
||||||
return v8::Null(isolate);
|
return v8::Null(isolate);
|
||||||
v8::Local<v8::Function> holder = function.NewHandle(isolate);
|
v8::Local<v8::Function> holder = function.NewHandle(isolate);
|
||||||
v8::Local<v8::Context> context = holder->GetCreationContextChecked();
|
v8::Local<v8::Context> context = holder->GetCreationContextChecked();
|
||||||
gin_helper::MicrotasksScope microtasks_scope(
|
gin_helper::MicrotasksScope microtasks_scope{
|
||||||
isolate, context->GetMicrotaskQueue(), true);
|
isolate, context->GetMicrotaskQueue(), true,
|
||||||
|
v8::MicrotasksScope::kRunMicrotasks};
|
||||||
v8::Context::Scope context_scope(context);
|
v8::Context::Scope context_scope(context);
|
||||||
std::vector<v8::Local<v8::Value>> args{
|
std::vector<v8::Local<v8::Value>> args{
|
||||||
gin::ConvertToV8(isolate, std::forward<ArgTypes>(raw))...};
|
gin::ConvertToV8(isolate, std::forward<ArgTypes>(raw))...};
|
||||||
|
@ -75,8 +76,9 @@ struct V8FunctionInvoker<void(ArgTypes...)> {
|
||||||
return;
|
return;
|
||||||
v8::Local<v8::Function> holder = function.NewHandle(isolate);
|
v8::Local<v8::Function> holder = function.NewHandle(isolate);
|
||||||
v8::Local<v8::Context> context = holder->GetCreationContextChecked();
|
v8::Local<v8::Context> context = holder->GetCreationContextChecked();
|
||||||
gin_helper::MicrotasksScope microtasks_scope(
|
gin_helper::MicrotasksScope microtasks_scope{
|
||||||
isolate, context->GetMicrotaskQueue(), true);
|
isolate, context->GetMicrotaskQueue(), true,
|
||||||
|
v8::MicrotasksScope::kRunMicrotasks};
|
||||||
v8::Context::Scope context_scope(context);
|
v8::Context::Scope context_scope(context);
|
||||||
std::vector<v8::Local<v8::Value>> args{
|
std::vector<v8::Local<v8::Value>> args{
|
||||||
gin::ConvertToV8(isolate, std::forward<ArgTypes>(raw))...};
|
gin::ConvertToV8(isolate, std::forward<ArgTypes>(raw))...};
|
||||||
|
@ -99,8 +101,9 @@ struct V8FunctionInvoker<ReturnType(ArgTypes...)> {
|
||||||
return ret;
|
return ret;
|
||||||
v8::Local<v8::Function> holder = function.NewHandle(isolate);
|
v8::Local<v8::Function> holder = function.NewHandle(isolate);
|
||||||
v8::Local<v8::Context> context = holder->GetCreationContextChecked();
|
v8::Local<v8::Context> context = holder->GetCreationContextChecked();
|
||||||
gin_helper::MicrotasksScope microtasks_scope(
|
gin_helper::MicrotasksScope microtasks_scope{
|
||||||
isolate, context->GetMicrotaskQueue(), true);
|
isolate, context->GetMicrotaskQueue(), true,
|
||||||
|
v8::MicrotasksScope::kRunMicrotasks};
|
||||||
v8::Context::Scope context_scope(context);
|
v8::Context::Scope context_scope(context);
|
||||||
std::vector<v8::Local<v8::Value>> args{
|
std::vector<v8::Local<v8::Value>> args{
|
||||||
gin::ConvertToV8(isolate, std::forward<ArgTypes>(raw))...};
|
gin::ConvertToV8(isolate, std::forward<ArgTypes>(raw))...};
|
||||||
|
|
|
@ -24,8 +24,9 @@ v8::Local<v8::Value> CallMethodWithArgs(v8::Isolate* isolate,
|
||||||
}
|
}
|
||||||
|
|
||||||
// Perform microtask checkpoint after running JavaScript.
|
// Perform microtask checkpoint after running JavaScript.
|
||||||
gin_helper::MicrotasksScope microtasks_scope(
|
gin_helper::MicrotasksScope microtasks_scope{
|
||||||
isolate, obj->GetCreationContextChecked()->GetMicrotaskQueue(), true);
|
isolate, obj->GetCreationContextChecked()->GetMicrotaskQueue(), true,
|
||||||
|
v8::MicrotasksScope::kRunMicrotasks};
|
||||||
|
|
||||||
// node::MakeCallback will also run pending tasks in Node.js.
|
// node::MakeCallback will also run pending tasks in Node.js.
|
||||||
v8::MaybeLocal<v8::Value> ret = node::MakeCallback(
|
v8::MaybeLocal<v8::Value> ret = node::MakeCallback(
|
||||||
|
|
|
@ -262,9 +262,10 @@ class Invoker<std::index_sequence<indices...>, ArgTypes...>
|
||||||
template <typename ReturnType>
|
template <typename ReturnType>
|
||||||
void DispatchToCallback(
|
void DispatchToCallback(
|
||||||
base::RepeatingCallback<ReturnType(ArgTypes...)> callback) {
|
base::RepeatingCallback<ReturnType(ArgTypes...)> callback) {
|
||||||
gin_helper::MicrotasksScope microtasks_scope(
|
gin_helper::MicrotasksScope microtasks_scope{
|
||||||
args_->isolate(),
|
args_->isolate(),
|
||||||
args_->GetHolderCreationContext()->GetMicrotaskQueue(), true);
|
args_->GetHolderCreationContext()->GetMicrotaskQueue(), true,
|
||||||
|
v8::MicrotasksScope::kRunMicrotasks};
|
||||||
args_->Return(
|
args_->Return(
|
||||||
callback.Run(std::move(ArgumentHolder<indices, ArgTypes>::value)...));
|
callback.Run(std::move(ArgumentHolder<indices, ArgTypes>::value)...));
|
||||||
}
|
}
|
||||||
|
@ -273,9 +274,10 @@ class Invoker<std::index_sequence<indices...>, ArgTypes...>
|
||||||
// expression to foo. As a result, we must specialize the case of Callbacks
|
// expression to foo. As a result, we must specialize the case of Callbacks
|
||||||
// that have the void return type.
|
// that have the void return type.
|
||||||
void DispatchToCallback(base::RepeatingCallback<void(ArgTypes...)> callback) {
|
void DispatchToCallback(base::RepeatingCallback<void(ArgTypes...)> callback) {
|
||||||
gin_helper::MicrotasksScope microtasks_scope(
|
gin_helper::MicrotasksScope microtasks_scope{
|
||||||
args_->isolate(),
|
args_->isolate(),
|
||||||
args_->GetHolderCreationContext()->GetMicrotaskQueue(), true);
|
args_->GetHolderCreationContext()->GetMicrotaskQueue(), true,
|
||||||
|
v8::MicrotasksScope::kRunMicrotasks};
|
||||||
callback.Run(std::move(ArgumentHolder<indices, ArgTypes>::value)...);
|
callback.Run(std::move(ArgumentHolder<indices, ArgTypes>::value)...);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -15,11 +15,10 @@ namespace gin_helper {
|
||||||
// In the render process creates a v8::MicrotasksScope.
|
// In the render process creates a v8::MicrotasksScope.
|
||||||
class MicrotasksScope {
|
class MicrotasksScope {
|
||||||
public:
|
public:
|
||||||
explicit MicrotasksScope(v8::Isolate* isolate,
|
MicrotasksScope(v8::Isolate* isolate,
|
||||||
v8::MicrotaskQueue* microtask_queue,
|
v8::MicrotaskQueue* microtask_queue,
|
||||||
bool ignore_browser_checkpoint = false,
|
bool ignore_browser_checkpoint,
|
||||||
v8::MicrotasksScope::Type scope_type =
|
v8::MicrotasksScope::Type scope_type);
|
||||||
v8::MicrotasksScope::kRunMicrotasks);
|
|
||||||
~MicrotasksScope();
|
~MicrotasksScope();
|
||||||
|
|
||||||
// disable copy
|
// disable copy
|
||||||
|
|
|
@ -29,8 +29,9 @@ PromiseBase& PromiseBase::operator=(PromiseBase&&) = default;
|
||||||
|
|
||||||
v8::Maybe<bool> PromiseBase::Reject() {
|
v8::Maybe<bool> PromiseBase::Reject() {
|
||||||
v8::HandleScope handle_scope(isolate());
|
v8::HandleScope handle_scope(isolate());
|
||||||
gin_helper::MicrotasksScope microtasks_scope(
|
gin_helper::MicrotasksScope microtasks_scope{
|
||||||
isolate(), GetContext()->GetMicrotaskQueue());
|
isolate(), GetContext()->GetMicrotaskQueue(), false,
|
||||||
|
v8::MicrotasksScope::kRunMicrotasks};
|
||||||
v8::Context::Scope context_scope(GetContext());
|
v8::Context::Scope context_scope(GetContext());
|
||||||
|
|
||||||
return GetInner()->Reject(GetContext(), v8::Undefined(isolate()));
|
return GetInner()->Reject(GetContext(), v8::Undefined(isolate()));
|
||||||
|
@ -38,8 +39,9 @@ v8::Maybe<bool> PromiseBase::Reject() {
|
||||||
|
|
||||||
v8::Maybe<bool> PromiseBase::Reject(v8::Local<v8::Value> except) {
|
v8::Maybe<bool> PromiseBase::Reject(v8::Local<v8::Value> except) {
|
||||||
v8::HandleScope handle_scope(isolate());
|
v8::HandleScope handle_scope(isolate());
|
||||||
gin_helper::MicrotasksScope microtasks_scope(
|
gin_helper::MicrotasksScope microtasks_scope{
|
||||||
isolate(), GetContext()->GetMicrotaskQueue());
|
isolate(), GetContext()->GetMicrotaskQueue(), false,
|
||||||
|
v8::MicrotasksScope::kRunMicrotasks};
|
||||||
v8::Context::Scope context_scope(GetContext());
|
v8::Context::Scope context_scope(GetContext());
|
||||||
|
|
||||||
return GetInner()->Reject(GetContext(), except);
|
return GetInner()->Reject(GetContext(), except);
|
||||||
|
@ -48,8 +50,9 @@ v8::Maybe<bool> PromiseBase::Reject(v8::Local<v8::Value> except) {
|
||||||
v8::Maybe<bool> PromiseBase::RejectWithErrorMessage(
|
v8::Maybe<bool> PromiseBase::RejectWithErrorMessage(
|
||||||
const std::string_view message) {
|
const std::string_view message) {
|
||||||
v8::HandleScope handle_scope(isolate());
|
v8::HandleScope handle_scope(isolate());
|
||||||
gin_helper::MicrotasksScope microtasks_scope(
|
gin_helper::MicrotasksScope microtasks_scope{
|
||||||
isolate(), GetContext()->GetMicrotaskQueue());
|
isolate(), GetContext()->GetMicrotaskQueue(), false,
|
||||||
|
v8::MicrotasksScope::kRunMicrotasks};
|
||||||
v8::Context::Scope context_scope(GetContext());
|
v8::Context::Scope context_scope(GetContext());
|
||||||
|
|
||||||
v8::Local<v8::Value> error =
|
v8::Local<v8::Value> error =
|
||||||
|
@ -91,8 +94,9 @@ v8::Local<v8::Promise> Promise<void>::ResolvedPromise(v8::Isolate* isolate) {
|
||||||
|
|
||||||
v8::Maybe<bool> Promise<void>::Resolve() {
|
v8::Maybe<bool> Promise<void>::Resolve() {
|
||||||
v8::HandleScope handle_scope(isolate());
|
v8::HandleScope handle_scope(isolate());
|
||||||
gin_helper::MicrotasksScope microtasks_scope(
|
gin_helper::MicrotasksScope microtasks_scope{
|
||||||
isolate(), GetContext()->GetMicrotaskQueue());
|
isolate(), GetContext()->GetMicrotaskQueue(), false,
|
||||||
|
v8::MicrotasksScope::kRunMicrotasks};
|
||||||
v8::Context::Scope context_scope(GetContext());
|
v8::Context::Scope context_scope(GetContext());
|
||||||
|
|
||||||
return GetInner()->Resolve(GetContext(), v8::Undefined(isolate()));
|
return GetInner()->Resolve(GetContext(), v8::Undefined(isolate()));
|
||||||
|
|
|
@ -122,8 +122,9 @@ class Promise : public PromiseBase {
|
||||||
v8::Maybe<bool> Resolve(const RT& value) {
|
v8::Maybe<bool> Resolve(const RT& value) {
|
||||||
gin_helper::Locker locker(isolate());
|
gin_helper::Locker locker(isolate());
|
||||||
v8::HandleScope handle_scope(isolate());
|
v8::HandleScope handle_scope(isolate());
|
||||||
gin_helper::MicrotasksScope microtasks_scope(
|
gin_helper::MicrotasksScope microtasks_scope{
|
||||||
isolate(), GetContext()->GetMicrotaskQueue());
|
isolate(), GetContext()->GetMicrotaskQueue(), false,
|
||||||
|
v8::MicrotasksScope::kRunMicrotasks};
|
||||||
v8::Context::Scope context_scope(GetContext());
|
v8::Context::Scope context_scope(GetContext());
|
||||||
|
|
||||||
return GetInner()->Resolve(GetContext(),
|
return GetInner()->Resolve(GetContext(),
|
||||||
|
|
|
@ -286,7 +286,7 @@ void ErrorMessageListener(v8::Local<v8::Message> message,
|
||||||
node::Environment* env = node::Environment::GetCurrent(isolate);
|
node::Environment* env = node::Environment::GetCurrent(isolate);
|
||||||
if (env) {
|
if (env) {
|
||||||
gin_helper::MicrotasksScope microtasks_scope(
|
gin_helper::MicrotasksScope microtasks_scope(
|
||||||
isolate, env->context()->GetMicrotaskQueue(),
|
isolate, env->context()->GetMicrotaskQueue(), false,
|
||||||
v8::MicrotasksScope::kDoNotRunMicrotasks);
|
v8::MicrotasksScope::kDoNotRunMicrotasks);
|
||||||
// Emit the after() hooks now that the exception has been handled.
|
// Emit the after() hooks now that the exception has been handled.
|
||||||
// Analogous to node/lib/internal/process/execution.js#L176-L180
|
// Analogous to node/lib/internal/process/execution.js#L176-L180
|
||||||
|
|
|
@ -34,9 +34,9 @@ class V8Serializer : public v8::ValueSerializer::Delegate {
|
||||||
~V8Serializer() override = default;
|
~V8Serializer() override = default;
|
||||||
|
|
||||||
bool Serialize(v8::Local<v8::Value> value, blink::CloneableMessage* out) {
|
bool Serialize(v8::Local<v8::Value> value, blink::CloneableMessage* out) {
|
||||||
gin_helper::MicrotasksScope microtasks_scope(
|
gin_helper::MicrotasksScope microtasks_scope{
|
||||||
isolate_, isolate_->GetCurrentContext()->GetMicrotaskQueue(),
|
isolate_, isolate_->GetCurrentContext()->GetMicrotaskQueue(), false,
|
||||||
v8::MicrotasksScope::kDoNotRunMicrotasks);
|
v8::MicrotasksScope::kDoNotRunMicrotasks};
|
||||||
WriteBlinkEnvelope(19);
|
WriteBlinkEnvelope(19);
|
||||||
|
|
||||||
serializer_.WriteHeader();
|
serializer_.WriteHeader();
|
||||||
|
|
|
@ -220,9 +220,9 @@ void SpellCheckClient::SpellCheckWords(const SpellCheckScope& scope,
|
||||||
DCHECK(!scope.spell_check_.IsEmpty());
|
DCHECK(!scope.spell_check_.IsEmpty());
|
||||||
|
|
||||||
auto context = isolate_->GetCurrentContext();
|
auto context = isolate_->GetCurrentContext();
|
||||||
gin_helper::MicrotasksScope microtasks_scope(
|
gin_helper::MicrotasksScope microtasks_scope{
|
||||||
isolate_, context->GetMicrotaskQueue(),
|
isolate_, context->GetMicrotaskQueue(), false,
|
||||||
v8::MicrotasksScope::kDoNotRunMicrotasks);
|
v8::MicrotasksScope::kDoNotRunMicrotasks};
|
||||||
|
|
||||||
v8::Local<v8::FunctionTemplate> templ = gin_helper::CreateFunctionTemplate(
|
v8::Local<v8::FunctionTemplate> templ = gin_helper::CreateFunctionTemplate(
|
||||||
isolate_,
|
isolate_,
|
||||||
|
|
|
@ -207,9 +207,9 @@ void ElectronSandboxedRendererClient::WillReleaseScriptContext(
|
||||||
return;
|
return;
|
||||||
|
|
||||||
auto* isolate = context->GetIsolate();
|
auto* isolate = context->GetIsolate();
|
||||||
gin_helper::MicrotasksScope microtasks_scope(
|
gin_helper::MicrotasksScope microtasks_scope{
|
||||||
isolate, context->GetMicrotaskQueue(),
|
isolate, context->GetMicrotaskQueue(), false,
|
||||||
v8::MicrotasksScope::kDoNotRunMicrotasks);
|
v8::MicrotasksScope::kDoNotRunMicrotasks};
|
||||||
v8::HandleScope handle_scope(isolate);
|
v8::HandleScope handle_scope(isolate);
|
||||||
v8::Context::Scope context_scope(context);
|
v8::Context::Scope context_scope(context);
|
||||||
InvokeEmitProcessEvent(context, "exit");
|
InvokeEmitProcessEvent(context, "exit");
|
||||||
|
@ -226,9 +226,9 @@ void ElectronSandboxedRendererClient::EmitProcessEvent(
|
||||||
v8::HandleScope handle_scope{isolate};
|
v8::HandleScope handle_scope{isolate};
|
||||||
|
|
||||||
v8::Local<v8::Context> context = GetContext(frame, isolate);
|
v8::Local<v8::Context> context = GetContext(frame, isolate);
|
||||||
gin_helper::MicrotasksScope microtasks_scope(
|
gin_helper::MicrotasksScope microtasks_scope{
|
||||||
isolate, context->GetMicrotaskQueue(),
|
isolate, context->GetMicrotaskQueue(), false,
|
||||||
v8::MicrotasksScope::kDoNotRunMicrotasks);
|
v8::MicrotasksScope::kDoNotRunMicrotasks};
|
||||||
v8::Context::Scope context_scope(context);
|
v8::Context::Scope context_scope(context);
|
||||||
|
|
||||||
InvokeEmitProcessEvent(context, event_name);
|
InvokeEmitProcessEvent(context, event_name);
|
||||||
|
|
Loading…
Reference in a new issue