Add EmitEvent function to replace node::MakeCallback

This commit is contained in:
Cheng Zhao 2015-06-23 19:46:37 +08:00
parent 197a9b4165
commit 78459b913b
5 changed files with 87 additions and 26 deletions

View file

@ -8,8 +8,6 @@
#include "native_mate/arguments.h" #include "native_mate/arguments.h"
#include "native_mate/object_template_builder.h" #include "native_mate/object_template_builder.h"
#include "atom/common/node_includes.h"
namespace mate { namespace mate {
namespace { namespace {
@ -38,11 +36,9 @@ v8::Local<v8::Object> CreateEventObject(v8::Isolate* isolate) {
EventEmitter::EventEmitter() { EventEmitter::EventEmitter() {
} }
bool EventEmitter::CallEmit(v8::Isolate* isolate, v8::Local<v8::Object> EventEmitter::CreateEvent(v8::Isolate* isolate,
const base::StringPiece& name,
content::WebContents* sender, content::WebContents* sender,
IPC::Message* message, IPC::Message* message) const {
ValueArray args) {
v8::Local<v8::Object> event; v8::Local<v8::Object> event;
bool use_native_event = sender && message; bool use_native_event = sender && message;
@ -53,16 +49,7 @@ bool EventEmitter::CallEmit(v8::Isolate* isolate,
} else { } else {
event = CreateEventObject(isolate); event = CreateEventObject(isolate);
} }
return event;
// args = [name, event, args...];
args.insert(args.begin(), event);
args.insert(args.begin(), mate::StringToV8(isolate, name));
// this.emit.apply(this, args);
node::MakeCallback(isolate, GetWrapper(isolate), "emit", args.size(),
&args[0]);
return event->Get(StringToV8(isolate, "defaultPrevented"))->BooleanValue();
} }
} // namespace mate } // namespace mate

View file

@ -7,6 +7,7 @@
#include <vector> #include <vector>
#include "atom/common/event_emitter_caller.h"
#include "native_mate/wrappable.h" #include "native_mate/wrappable.h"
namespace content { namespace content {
@ -41,18 +42,16 @@ class EventEmitter : public Wrappable {
const Args&... args) { const Args&... args) {
v8::Locker locker(isolate()); v8::Locker locker(isolate());
v8::HandleScope handle_scope(isolate()); v8::HandleScope handle_scope(isolate());
v8::Local<v8::Object> event = CreateEvent(isolate(), sender, message);
ValueArray converted = { ConvertToV8(isolate(), args)... }; EmitEvent(isolate(), GetWrapper(isolate()), name, event, args...);
return CallEmit(isolate(), name, sender, message, converted); return event->Get(
StringToV8(isolate(), "defaultPrevented"))->BooleanValue();
} }
private: private:
// Lower level implementations. v8::Local<v8::Object> CreateEvent(v8::Isolate* isolate,
bool CallEmit(v8::Isolate* isolate,
const base::StringPiece& name,
content::WebContents* sender, content::WebContents* sender,
IPC::Message* message, IPC::Message* message) const;
ValueArray args);
DISALLOW_COPY_AND_ASSIGN(EventEmitter); DISALLOW_COPY_AND_ASSIGN(EventEmitter);
}; };

View file

@ -0,0 +1,33 @@
// Copyright (c) 2015 GitHub, Inc.
// Use of this source code is governed by the MIT license that can be
// found in the LICENSE file.
#include "atom/common/event_emitter_caller.h"
namespace mate {
namespace internal {
v8::Local<v8::Value> CallEmitWithArgs(v8::Isolate* isolate,
v8::Local<v8::Object> obj,
ValueVector* args) {
v8::Local<v8::String> emit_name = StringToSymbol(isolate, "emit");
v8::Local<v8::Value> emit = obj->Get(emit_name);
if (emit.IsEmpty() || !emit->IsFunction()) {
isolate->ThrowException(v8::Exception::TypeError(
StringToV8(isolate, "\"emit\" is not a function")));
return v8::Undefined(isolate);
}
v8::MaybeLocal<v8::Value> result = emit.As<v8::Function>()->Call(
isolate->GetCurrentContext(), obj, args->size(), &args->front());
if (result.IsEmpty()) {
return v8::Undefined(isolate);
}
return result.ToLocalChecked();
}
} // namespace internal
} // namespace mate

View file

@ -0,0 +1,40 @@
// Copyright (c) 2015 GitHub, Inc.
// Use of this source code is governed by the MIT license that can be
// found in the LICENSE file.
#ifndef ATOM_COMMON_EVENT_EMITTER_CALLER_H_
#define ATOM_COMMON_EVENT_EMITTER_CALLER_H_
#include <vector>
#include "native_mate/converter.h"
namespace mate {
namespace internal {
using ValueVector = std::vector<v8::Local<v8::Value>>;
v8::Local<v8::Value> CallEmitWithArgs(v8::Isolate* isolate,
v8::Local<v8::Object> obj,
ValueVector* args);
} // namespace internal
// obj.emit(name, args...);
// The caller is responsible of allocating a HandleScope.
template<typename... Args>
v8::Local<v8::Value> EmitEvent(v8::Isolate* isolate,
v8::Local<v8::Object> obj,
const base::StringPiece& name,
const Args&... args) {
internal::ValueVector converted_args = {
ConvertToV8(isolate, name),
ConvertToV8(isolate, args)...,
};
return internal::CallEmitWithArgs(isolate, obj, &converted_args);
}
} // namespace mate
#endif // ATOM_COMMON_EVENT_EMITTER_CALLER_H_

View file

@ -249,6 +249,8 @@
'atom/common/crash_reporter/win/crash_service_main.h', 'atom/common/crash_reporter/win/crash_service_main.h',
'atom/common/draggable_region.cc', 'atom/common/draggable_region.cc',
'atom/common/draggable_region.h', 'atom/common/draggable_region.h',
'atom/common/event_emitter_caller.cc',
'atom/common/event_emitter_caller.h',
'atom/common/google_api_key.h', 'atom/common/google_api_key.h',
'atom/common/linux/application_info.cc', 'atom/common/linux/application_info.cc',
'atom/common/native_mate_converters/accelerator_converter.cc', 'atom/common/native_mate_converters/accelerator_converter.cc',