Add EmitEvent function to replace node::MakeCallback
This commit is contained in:
parent
197a9b4165
commit
78459b913b
5 changed files with 87 additions and 26 deletions
|
@ -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
|
||||||
|
|
|
@ -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);
|
||||||
};
|
};
|
||||||
|
|
33
atom/common/event_emitter_caller.cc
Normal file
33
atom/common/event_emitter_caller.cc
Normal 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
|
40
atom/common/event_emitter_caller.h
Normal file
40
atom/common/event_emitter_caller.h
Normal 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_
|
|
@ -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',
|
||||||
|
|
Loading…
Reference in a new issue