Use native_mate based Event in browser_ipc.
This commit is contained in:
parent
da483ba7f3
commit
f36569c3b9
3 changed files with 7 additions and 8 deletions
|
@ -6,6 +6,7 @@
|
||||||
#include "atom/common/native_mate_converters/string16_converter.h"
|
#include "atom/common/native_mate_converters/string16_converter.h"
|
||||||
#include "atom/common/native_mate_converters/value_converter.h"
|
#include "atom/common/native_mate_converters/value_converter.h"
|
||||||
#include "content/public/browser/render_view_host.h"
|
#include "content/public/browser/render_view_host.h"
|
||||||
|
#include "native_mate/dictionary.h"
|
||||||
|
|
||||||
#include "atom/common/node_includes.h"
|
#include "atom/common/node_includes.h"
|
||||||
|
|
||||||
|
@ -14,7 +15,7 @@ using content::RenderViewHost;
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
bool Send(const string16& channel, int process_id, int routing_id,
|
bool Send(const string16& channel, int process_id, int routing_id,
|
||||||
const base:ListValue& arguments) {
|
const base::ListValue& arguments) {
|
||||||
RenderViewHost* render_view_host(RenderViewHost::FromID(
|
RenderViewHost* render_view_host(RenderViewHost::FromID(
|
||||||
process_id, routing_id));
|
process_id, routing_id));
|
||||||
if (!render_view_host) {
|
if (!render_view_host) {
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "base/logging.h"
|
#include "base/logging.h"
|
||||||
#include "atom/browser/api/atom_api_event.h"
|
#include "atom/browser/api/event.h"
|
||||||
#include "atom/common/v8/native_type_conversions.h"
|
#include "atom/common/v8/native_type_conversions.h"
|
||||||
#include "content/public/browser/browser_thread.h"
|
#include "content/public/browser/browser_thread.h"
|
||||||
|
|
||||||
|
@ -65,8 +65,8 @@ void AtomBrowserBindings::OnRendererMessageSync(
|
||||||
scoped_ptr<V8ValueConverter> converter(new V8ValueConverter);
|
scoped_ptr<V8ValueConverter> converter(new V8ValueConverter);
|
||||||
|
|
||||||
// Create the event object.
|
// Create the event object.
|
||||||
v8::Handle<v8::Object> event = api::Event::CreateV8Object();
|
mate::Handle<mate::Event> event = mate::Event::Create(node_isolate);
|
||||||
api::Event::Unwrap<api::Event>(event)->SetSenderAndMessage(sender, message);
|
event->SetSenderAndMessage(sender, message);
|
||||||
|
|
||||||
// process.emit(channel, 'sync-message', event, process_id, routing_id);
|
// process.emit(channel, 'sync-message', event, process_id, routing_id);
|
||||||
std::vector<v8::Handle<v8::Value>> arguments;
|
std::vector<v8::Handle<v8::Value>> arguments;
|
||||||
|
@ -75,7 +75,7 @@ void AtomBrowserBindings::OnRendererMessageSync(
|
||||||
const base::Value* value;
|
const base::Value* value;
|
||||||
if (args.Get(0, &value))
|
if (args.Get(0, &value))
|
||||||
arguments.push_back(converter->ToV8Value(value, global_env->context()));
|
arguments.push_back(converter->ToV8Value(value, global_env->context()));
|
||||||
arguments.push_back(event);
|
arguments.push_back(event.ToV8());
|
||||||
arguments.push_back(v8::Integer::New(process_id));
|
arguments.push_back(v8::Integer::New(process_id));
|
||||||
arguments.push_back(v8::Integer::New(routing_id));
|
arguments.push_back(v8::Integer::New(routing_id));
|
||||||
|
|
||||||
|
|
|
@ -61,12 +61,10 @@ describe 'ipc module', ->
|
||||||
msg = ipc.sendChannelSync 'echo', 'test'
|
msg = ipc.sendChannelSync 'echo', 'test'
|
||||||
assert.equal msg, 'test'
|
assert.equal msg, 'test'
|
||||||
|
|
||||||
it 'does not crash when reply is not sent and both browser and event are destroyed', (done) ->
|
it 'does not crash when reply is not sent and browser is destroyed', (done) ->
|
||||||
w = new BrowserWindow(show: false)
|
w = new BrowserWindow(show: false)
|
||||||
remote.require('ipc').once 'send-sync-message', (event) ->
|
remote.require('ipc').once 'send-sync-message', (event) ->
|
||||||
event.returnValue = null
|
event.returnValue = null
|
||||||
|
|
||||||
w.destroy()
|
w.destroy()
|
||||||
event.destroy()
|
|
||||||
done()
|
done()
|
||||||
w.loadUrl 'file://' + path.join(fixtures, 'api', 'send-sync-message.html')
|
w.loadUrl 'file://' + path.join(fixtures, 'api', 'send-sync-message.html')
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue