// Copyright (c) 2019 GitHub, Inc. // Use of this source code is governed by the MIT license that can be // found in the LICENSE file. #ifndef ELECTRON_SHELL_COMMON_GIN_HELPER_EVENT_EMITTER_CALLER_H_ #define ELECTRON_SHELL_COMMON_GIN_HELPER_EVENT_EMITTER_CALLER_H_ #include #include #include "base/containers/span.h" #include "gin/converter.h" #include "gin/wrappable.h" namespace gin_helper { namespace internal { v8::Local CallMethodWithArgs(v8::Isolate* isolate, v8::Local obj, const char* method, base::span> args); } // namespace internal // obj.emit(name, args...); // The caller is responsible of allocating a HandleScope. template v8::Local EmitEvent(v8::Isolate* isolate, v8::Local obj, const StringType& name, Args&&... args) { v8::EscapableHandleScope scope{isolate}; std::array, 1U + sizeof...(args)> converted_args = { gin::StringToV8(isolate, name), gin::ConvertToV8(isolate, std::forward(args))..., }; return scope.Escape( internal::CallMethodWithArgs(isolate, obj, "emit", converted_args)); } // obj.custom_emit(args...) template v8::Local CustomEmit(v8::Isolate* isolate, v8::Local object, const char* custom_emit, Args&&... args) { v8::EscapableHandleScope scope{isolate}; std::array, sizeof...(args)> converted_args = { gin::ConvertToV8(isolate, std::forward(args))..., }; return scope.Escape(internal::CallMethodWithArgs(isolate, object, custom_emit, converted_args)); } template v8::Local CallMethod(v8::Isolate* isolate, gin::Wrappable* object, const char* method_name, Args&&... args) { v8::EscapableHandleScope scope(isolate); v8::Local v8_object; if (object->GetWrapper(isolate).ToLocal(&v8_object)) return scope.Escape(CustomEmit(isolate, v8_object, method_name, std::forward(args)...)); else return {}; } template v8::Local CallMethod(gin::Wrappable* object, const char* method_name, Args&&... args) { v8::Isolate* isolate = v8::Isolate::GetCurrent(); return CallMethod(isolate, object, method_name, std::forward(args)...); } } // namespace gin_helper #endif // ELECTRON_SHELL_COMMON_GIN_HELPER_EVENT_EMITTER_CALLER_H_