perf: hold V8FunctionInvoker
args in a std::array
(#43752)
perf: hold V8FunctionInvoker args in a std::array
This commit is contained in:
parent
8cff5a7d20
commit
5904d31264
1 changed files with 4 additions and 4 deletions
|
@ -5,8 +5,8 @@
|
||||||
#ifndef ELECTRON_SHELL_COMMON_GIN_HELPER_CALLBACK_H_
|
#ifndef ELECTRON_SHELL_COMMON_GIN_HELPER_CALLBACK_H_
|
||||||
#define ELECTRON_SHELL_COMMON_GIN_HELPER_CALLBACK_H_
|
#define ELECTRON_SHELL_COMMON_GIN_HELPER_CALLBACK_H_
|
||||||
|
|
||||||
|
#include <array>
|
||||||
#include <utility>
|
#include <utility>
|
||||||
#include <vector>
|
|
||||||
|
|
||||||
#include "base/functional/bind.h"
|
#include "base/functional/bind.h"
|
||||||
#include "shell/common/gin_converters/std_converter.h"
|
#include "shell/common/gin_converters/std_converter.h"
|
||||||
|
@ -54,7 +54,7 @@ struct V8FunctionInvoker<v8::Local<v8::Value>(ArgTypes...)> {
|
||||||
isolate, context->GetMicrotaskQueue(), true,
|
isolate, context->GetMicrotaskQueue(), true,
|
||||||
v8::MicrotasksScope::kRunMicrotasks};
|
v8::MicrotasksScope::kRunMicrotasks};
|
||||||
v8::Context::Scope context_scope(context);
|
v8::Context::Scope context_scope(context);
|
||||||
std::vector<v8::Local<v8::Value>> args{
|
std::array<v8::Local<v8::Value>, sizeof...(raw)> args{
|
||||||
gin::ConvertToV8(isolate, std::forward<ArgTypes>(raw))...};
|
gin::ConvertToV8(isolate, std::forward<ArgTypes>(raw))...};
|
||||||
v8::MaybeLocal<v8::Value> ret = holder->Call(
|
v8::MaybeLocal<v8::Value> ret = holder->Call(
|
||||||
context, holder, args.size(), args.empty() ? nullptr : &args.front());
|
context, holder, args.size(), args.empty() ? nullptr : &args.front());
|
||||||
|
@ -80,7 +80,7 @@ struct V8FunctionInvoker<void(ArgTypes...)> {
|
||||||
isolate, context->GetMicrotaskQueue(), true,
|
isolate, context->GetMicrotaskQueue(), true,
|
||||||
v8::MicrotasksScope::kRunMicrotasks};
|
v8::MicrotasksScope::kRunMicrotasks};
|
||||||
v8::Context::Scope context_scope(context);
|
v8::Context::Scope context_scope(context);
|
||||||
std::vector<v8::Local<v8::Value>> args{
|
std::array<v8::Local<v8::Value>, sizeof...(raw)> args{
|
||||||
gin::ConvertToV8(isolate, std::forward<ArgTypes>(raw))...};
|
gin::ConvertToV8(isolate, std::forward<ArgTypes>(raw))...};
|
||||||
holder
|
holder
|
||||||
->Call(context, holder, args.size(),
|
->Call(context, holder, args.size(),
|
||||||
|
@ -105,7 +105,7 @@ struct V8FunctionInvoker<ReturnType(ArgTypes...)> {
|
||||||
isolate, context->GetMicrotaskQueue(), true,
|
isolate, context->GetMicrotaskQueue(), true,
|
||||||
v8::MicrotasksScope::kRunMicrotasks};
|
v8::MicrotasksScope::kRunMicrotasks};
|
||||||
v8::Context::Scope context_scope(context);
|
v8::Context::Scope context_scope(context);
|
||||||
std::vector<v8::Local<v8::Value>> args{
|
std::array<v8::Local<v8::Value>, sizeof...(raw)> args{
|
||||||
gin::ConvertToV8(isolate, std::forward<ArgTypes>(raw))...};
|
gin::ConvertToV8(isolate, std::forward<ArgTypes>(raw))...};
|
||||||
v8::Local<v8::Value> result;
|
v8::Local<v8::Value> result;
|
||||||
auto maybe_result = holder->Call(context, holder, args.size(),
|
auto maybe_result = holder->Call(context, holder, args.size(),
|
||||||
|
|
Loading…
Reference in a new issue