Allow passing V8 objects in EventEmitter
This commit is contained in:
parent
485bd7bbd3
commit
d8447524cb
2 changed files with 35 additions and 15 deletions
|
@ -4,8 +4,6 @@
|
||||||
|
|
||||||
#include "atom/browser/api/event_emitter.h"
|
#include "atom/browser/api/event_emitter.h"
|
||||||
|
|
||||||
#include <vector>
|
|
||||||
|
|
||||||
#include "atom/browser/api/event.h"
|
#include "atom/browser/api/event.h"
|
||||||
#include "atom/common/native_mate_converters/v8_value_converter.h"
|
#include "atom/common/native_mate_converters/v8_value_converter.h"
|
||||||
#include "base/memory/scoped_ptr.h"
|
#include "base/memory/scoped_ptr.h"
|
||||||
|
@ -64,6 +62,23 @@ bool EventEmitter::Emit(const base::StringPiece& name,
|
||||||
v8::Handle<v8::Context> context = isolate->GetCurrentContext();
|
v8::Handle<v8::Context> context = isolate->GetCurrentContext();
|
||||||
scoped_ptr<atom::V8ValueConverter> converter(new atom::V8ValueConverter);
|
scoped_ptr<atom::V8ValueConverter> converter(new atom::V8ValueConverter);
|
||||||
|
|
||||||
|
// v8_args = [args...];
|
||||||
|
Arguments v8_args;
|
||||||
|
v8_args.reserve(args.GetSize());
|
||||||
|
for (size_t i = 0; i < args.GetSize(); i++) {
|
||||||
|
const base::Value* value(NULL);
|
||||||
|
if (args.Get(i, &value))
|
||||||
|
v8_args.push_back(converter->ToV8Value(value, context));
|
||||||
|
}
|
||||||
|
|
||||||
|
return Emit(isolate, name, v8_args, sender, message);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool EventEmitter::Emit(v8::Isolate* isolate,
|
||||||
|
const base::StringPiece& name,
|
||||||
|
Arguments args,
|
||||||
|
content::WebContents* sender,
|
||||||
|
IPC::Message* message) {
|
||||||
v8::Handle<v8::Object> event;
|
v8::Handle<v8::Object> event;
|
||||||
bool use_native_event = sender && message;
|
bool use_native_event = sender && message;
|
||||||
|
|
||||||
|
@ -75,20 +90,13 @@ bool EventEmitter::Emit(const base::StringPiece& name,
|
||||||
event = CreateEventObject(isolate);
|
event = CreateEventObject(isolate);
|
||||||
}
|
}
|
||||||
|
|
||||||
// v8_args = [name, event, args...];
|
// args = [name, event, args...];
|
||||||
std::vector<v8::Handle<v8::Value>> v8_args;
|
args.insert(args.begin(), event);
|
||||||
v8_args.reserve(args.GetSize() + 2);
|
args.insert(args.begin(), mate::StringToV8(isolate, name));
|
||||||
v8_args.push_back(mate::StringToV8(isolate, name));
|
|
||||||
v8_args.push_back(event);
|
|
||||||
for (size_t i = 0; i < args.GetSize(); i++) {
|
|
||||||
const base::Value* value(NULL);
|
|
||||||
if (args.Get(i, &value))
|
|
||||||
v8_args.push_back(converter->ToV8Value(value, context));
|
|
||||||
}
|
|
||||||
|
|
||||||
// this.emit.apply(this, v8_args);
|
// this.emit.apply(this, args);
|
||||||
node::MakeCallback(isolate, GetWrapper(isolate), "emit", v8_args.size(),
|
node::MakeCallback(isolate, GetWrapper(isolate), "emit", args.size(),
|
||||||
&v8_args[0]);
|
&args[0]);
|
||||||
|
|
||||||
if (use_native_event) {
|
if (use_native_event) {
|
||||||
Handle<Event> native_event;
|
Handle<Event> native_event;
|
||||||
|
|
|
@ -5,6 +5,8 @@
|
||||||
#ifndef ATOM_BROWSER_API_EVENT_EMITTER_H_
|
#ifndef ATOM_BROWSER_API_EVENT_EMITTER_H_
|
||||||
#define ATOM_BROWSER_API_EVENT_EMITTER_H_
|
#define ATOM_BROWSER_API_EVENT_EMITTER_H_
|
||||||
|
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
#include "native_mate/wrappable.h"
|
#include "native_mate/wrappable.h"
|
||||||
|
|
||||||
namespace base {
|
namespace base {
|
||||||
|
@ -23,6 +25,9 @@ namespace mate {
|
||||||
|
|
||||||
// Provide helperers to emit event in JavaScript.
|
// Provide helperers to emit event in JavaScript.
|
||||||
class EventEmitter : public Wrappable {
|
class EventEmitter : public Wrappable {
|
||||||
|
public:
|
||||||
|
typedef std::vector<v8::Handle<v8::Value>> Arguments;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
EventEmitter();
|
EventEmitter();
|
||||||
|
|
||||||
|
@ -36,6 +41,13 @@ class EventEmitter : public Wrappable {
|
||||||
bool Emit(const base::StringPiece& name, const base::ListValue& args,
|
bool Emit(const base::StringPiece& name, const base::ListValue& args,
|
||||||
content::WebContents* sender, IPC::Message* message);
|
content::WebContents* sender, IPC::Message* message);
|
||||||
|
|
||||||
|
// Lower level implementations.
|
||||||
|
bool Emit(v8::Isolate* isolate,
|
||||||
|
const base::StringPiece& name,
|
||||||
|
Arguments args,
|
||||||
|
content::WebContents* sender = nullptr,
|
||||||
|
IPC::Message* message = nullptr);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
DISALLOW_COPY_AND_ASSIGN(EventEmitter);
|
DISALLOW_COPY_AND_ASSIGN(EventEmitter);
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue