Move node integration from RenderViewObserver to RendererClient.

This commit is contained in:
Cheng Zhao 2013-12-23 22:08:45 +08:00
parent 02d94c8b2e
commit df0094b6cb
6 changed files with 54 additions and 57 deletions

View file

@ -4,9 +4,6 @@
#include "renderer/api/atom_renderer_bindings.h" #include "renderer/api/atom_renderer_bindings.h"
#include <vector>
#include "base/logging.h"
#include "common/v8/native_type_conversions.h" #include "common/v8/native_type_conversions.h"
#include "content/public/renderer/render_view.h" #include "content/public/renderer/render_view.h"
#include "third_party/WebKit/public/web/WebFrame.h" #include "third_party/WebKit/public/web/WebFrame.h"
@ -14,9 +11,7 @@
#include "common/v8/node_common.h" #include "common/v8/node_common.h"
using content::RenderView;
using content::V8ValueConverter; using content::V8ValueConverter;
using WebKit::WebFrame;
namespace atom { namespace atom {
@ -32,14 +27,13 @@ v8::Handle<v8::Object> GetProcessObject(v8::Handle<v8::Context> context) {
} // namespace } // namespace
AtomRendererBindings::AtomRendererBindings(RenderView* render_view) AtomRendererBindings::AtomRendererBindings() {
: render_view_(render_view) {
} }
AtomRendererBindings::~AtomRendererBindings() { AtomRendererBindings::~AtomRendererBindings() {
} }
void AtomRendererBindings::BindToFrame(WebFrame* frame) { void AtomRendererBindings::BindToFrame(WebKit::WebFrame* frame) {
v8::HandleScope handle_scope(node_isolate); v8::HandleScope handle_scope(node_isolate);
v8::Handle<v8::Context> context = frame->mainWorldScriptContext(); v8::Handle<v8::Context> context = frame->mainWorldScriptContext();
@ -47,19 +41,19 @@ void AtomRendererBindings::BindToFrame(WebFrame* frame) {
return; return;
v8::Context::Scope scope(context); v8::Context::Scope scope(context);
AtomBindings::BindTo(GetProcessObject(context)); AtomBindings::BindTo(GetProcessObject(context));
} }
void AtomRendererBindings::OnBrowserMessage(const string16& channel, void AtomRendererBindings::OnBrowserMessage(content::RenderView* render_view,
const string16& channel,
const base::ListValue& args) { const base::ListValue& args) {
if (!render_view_->GetWebView()) if (!render_view->GetWebView())
return; return;
v8::HandleScope handle_scope(node_isolate); v8::HandleScope handle_scope(node_isolate);
v8::Local<v8::Context> context = v8::Local<v8::Context> context =
render_view_->GetWebView()->mainFrame()->mainWorldScriptContext(); render_view->GetWebView()->mainFrame()->mainWorldScriptContext();
if (context.IsEmpty()) if (context.IsEmpty())
return; return;

View file

@ -25,19 +25,18 @@ namespace atom {
class AtomRendererBindings : public AtomBindings { class AtomRendererBindings : public AtomBindings {
public: public:
explicit AtomRendererBindings(content::RenderView* render_view); AtomRendererBindings();
virtual ~AtomRendererBindings(); virtual ~AtomRendererBindings();
// Call BindTo for process object of the frame. // Call BindTo for process object of the frame.
void BindToFrame(WebKit::WebFrame* frame); void BindToFrame(WebKit::WebFrame* frame);
// Dispatch messages from browser. // Dispatch messages from browser.
void OnBrowserMessage(const string16& channel, void OnBrowserMessage(content::RenderView* render_view,
const string16& channel,
const base::ListValue& args); const base::ListValue& args);
private: private:
content::RenderView* render_view_;
DISALLOW_COPY_AND_ASSIGN(AtomRendererBindings); DISALLOW_COPY_AND_ASSIGN(AtomRendererBindings);
}; };

View file

@ -5,12 +5,11 @@
#include "renderer/atom_render_view_observer.h" #include "renderer/atom_render_view_observer.h"
#include "common/api/api_messages.h" #include "common/api/api_messages.h"
#include "common/node_bindings.h"
#include "ipc/ipc_message_macros.h" #include "ipc/ipc_message_macros.h"
#include "renderer/api/atom_renderer_bindings.h" #include "renderer/api/atom_renderer_bindings.h"
#include "renderer/atom_renderer_client.h" #include "renderer/atom_renderer_client.h"
#include "third_party/WebKit/public/web/WebDocument.h"
#include "third_party/WebKit/public/web/WebDraggableRegion.h" #include "third_party/WebKit/public/web/WebDraggableRegion.h"
#include "third_party/WebKit/public/web/WebDocument.h"
#include "third_party/WebKit/public/web/WebFrame.h" #include "third_party/WebKit/public/web/WebFrame.h"
#include "common/v8/node_common.h" #include "common/v8/node_common.h"
@ -23,36 +22,12 @@ AtomRenderViewObserver::AtomRenderViewObserver(
content::RenderView* render_view, content::RenderView* render_view,
AtomRendererClient* renderer_client) AtomRendererClient* renderer_client)
: content::RenderViewObserver(render_view), : content::RenderViewObserver(render_view),
atom_bindings_(new AtomRendererBindings(render_view)),
renderer_client_(renderer_client) { renderer_client_(renderer_client) {
} }
AtomRenderViewObserver::~AtomRenderViewObserver() { AtomRenderViewObserver::~AtomRenderViewObserver() {
} }
void AtomRenderViewObserver::DidClearWindowObject(WebFrame* frame) {
// Get the context.
v8::HandleScope handle_scope(node_isolate);
v8::Handle<v8::Context> context = frame->mainWorldScriptContext();
if (context.IsEmpty())
return;
v8::Context::Scope scope(context);
// Check the existance of process object to prevent duplicate initialization.
if (context->Global()->Has(v8::String::New("process")))
return;
// Give the node loop a run to make sure everything is ready.
renderer_client_->node_bindings()->RunMessageLoop();
// Setup node environment for each window.
renderer_client_->node_bindings()->CreateEnvironment(context);
// Add atom-shell extended APIs.
atom_bindings()->BindToFrame(frame);
}
void AtomRenderViewObserver::DraggableRegionsChanged(WebKit::WebFrame* frame) { void AtomRenderViewObserver::DraggableRegionsChanged(WebKit::WebFrame* frame) {
WebKit::WebVector<WebKit::WebDraggableRegion> webregions = WebKit::WebVector<WebKit::WebDraggableRegion> webregions =
frame->document().draggableRegions(); frame->document().draggableRegions();
@ -78,7 +53,8 @@ bool AtomRenderViewObserver::OnMessageReceived(const IPC::Message& message) {
void AtomRenderViewObserver::OnBrowserMessage(const string16& channel, void AtomRenderViewObserver::OnBrowserMessage(const string16& channel,
const base::ListValue& args) { const base::ListValue& args) {
atom_bindings()->OnBrowserMessage(channel, args); renderer_client_->atom_bindings()->OnBrowserMessage(
render_view(), channel, args);
} }
} // namespace atom } // namespace atom

View file

@ -5,7 +5,6 @@
#ifndef ATOM_RENDERER_ATOM_RENDER_VIEW_OBSERVER_ #ifndef ATOM_RENDERER_ATOM_RENDER_VIEW_OBSERVER_
#define ATOM_RENDERER_ATOM_RENDER_VIEW_OBSERVER_ #define ATOM_RENDERER_ATOM_RENDER_VIEW_OBSERVER_
#include "base/memory/scoped_ptr.h"
#include "content/public/renderer/render_view_observer.h" #include "content/public/renderer/render_view_observer.h"
namespace base { namespace base {
@ -14,21 +13,16 @@ class ListValue;
namespace atom { namespace atom {
class AtomRendererBindings;
class AtomRendererClient; class AtomRendererClient;
class AtomRenderViewObserver : content::RenderViewObserver { class AtomRenderViewObserver : public content::RenderViewObserver {
public: public:
explicit AtomRenderViewObserver(content::RenderView* render_view, explicit AtomRenderViewObserver(content::RenderView* render_view,
AtomRendererClient* renderer_client); AtomRendererClient* renderer_client);
AtomRendererBindings* atom_bindings() const { return atom_bindings_.get(); }
protected: protected:
virtual ~AtomRenderViewObserver(); virtual ~AtomRenderViewObserver();
virtual void DidClearWindowObject(WebKit::WebFrame*) OVERRIDE;
private: private:
// content::RenderViewObserver implementation. // content::RenderViewObserver implementation.
virtual void DraggableRegionsChanged(WebKit::WebFrame* frame) OVERRIDE; virtual void DraggableRegionsChanged(WebKit::WebFrame* frame) OVERRIDE;
@ -37,8 +31,6 @@ class AtomRenderViewObserver : content::RenderViewObserver {
void OnBrowserMessage(const string16& channel, void OnBrowserMessage(const string16& channel,
const base::ListValue& args); const base::ListValue& args);
scoped_ptr<AtomRendererBindings> atom_bindings_;
// Weak reference to renderer client. // Weak reference to renderer client.
AtomRendererClient* renderer_client_; AtomRendererClient* renderer_client_;

View file

@ -5,6 +5,7 @@
#include "renderer/atom_renderer_client.h" #include "renderer/atom_renderer_client.h"
#include "common/node_bindings.h" #include "common/node_bindings.h"
#include "renderer/api/atom_renderer_bindings.h"
#include "renderer/atom_render_view_observer.h" #include "renderer/atom_render_view_observer.h"
#include "common/v8/node_common.h" #include "common/v8/node_common.h"
@ -12,7 +13,8 @@
namespace atom { namespace atom {
AtomRendererClient::AtomRendererClient() AtomRendererClient::AtomRendererClient()
: node_bindings_(NodeBindings::Create(false)) { : node_bindings_(NodeBindings::Create(false)),
atom_bindings_(new AtomRendererBindings) {
} }
AtomRendererClient::~AtomRendererClient() { AtomRendererClient::~AtomRendererClient() {
@ -35,4 +37,29 @@ void AtomRendererClient::RenderViewCreated(content::RenderView* render_view) {
new AtomRenderViewObserver(render_view, this); new AtomRenderViewObserver(render_view, this);
} }
void AtomRendererClient::DidCreateScriptContext(WebKit::WebFrame* frame,
v8::Handle<v8::Context> context,
int extension_group,
int world_id) {
v8::Context::Scope scope(context);
// Check the existance of process object to prevent duplicate initialization.
if (context->Global()->Has(v8::String::New("process")))
return;
// Give the node loop a run to make sure everything is ready.
node_bindings_->RunMessageLoop();
// Setup node environment for each window.
node_bindings_->CreateEnvironment(context);
// Add atom-shell extended APIs.
atom_bindings_->BindToFrame(frame);
}
void AtomRendererClient::WillReleaseScriptContext(WebKit::WebFrame* frame,
v8::Handle<v8::Context>,
int world_id) {
}
} // namespace atom } // namespace atom

View file

@ -2,13 +2,14 @@
// Use of this source code is governed by a BSD-style license that can be // Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file. // found in the LICENSE file.
#ifndef ATOM_RENDERER_ATOM_RENDERER_CLIENT_ #ifndef ATOM_RENDERER_ATOM_RENDERER_CLIENT_H_
#define ATOM_RENDERER_ATOM_RENDERER_CLIENT_ #define ATOM_RENDERER_ATOM_RENDERER_CLIENT_H_
#include "content/public/renderer/content_renderer_client.h" #include "content/public/renderer/content_renderer_client.h"
namespace atom { namespace atom {
class AtomRendererBindings;
class NodeBindings; class NodeBindings;
class AtomRendererClient : public content::ContentRendererClient { class AtomRendererClient : public content::ContentRendererClient {
@ -16,17 +17,25 @@ class AtomRendererClient : public content::ContentRendererClient {
AtomRendererClient(); AtomRendererClient();
virtual ~AtomRendererClient(); virtual ~AtomRendererClient();
NodeBindings* node_bindings() const { return node_bindings_.get(); } AtomRendererBindings* atom_bindings() const { return atom_bindings_.get(); }
private: private:
virtual void RenderThreadStarted() OVERRIDE; virtual void RenderThreadStarted() OVERRIDE;
virtual void RenderViewCreated(content::RenderView*) OVERRIDE; virtual void RenderViewCreated(content::RenderView*) OVERRIDE;
virtual void DidCreateScriptContext(WebKit::WebFrame* frame,
v8::Handle<v8::Context> context,
int extension_group,
int world_id) OVERRIDE;
virtual void WillReleaseScriptContext(WebKit::WebFrame* frame,
v8::Handle<v8::Context>,
int world_id) OVERRIDE;
scoped_ptr<NodeBindings> node_bindings_; scoped_ptr<NodeBindings> node_bindings_;
scoped_ptr<AtomRendererBindings> atom_bindings_;
DISALLOW_COPY_AND_ASSIGN(AtomRendererClient); DISALLOW_COPY_AND_ASSIGN(AtomRendererClient);
}; };
} // namespace atom } // namespace atom
#endif // ATOM_RENDERER_ATOM_RENDERER_CLIENT_ #endif // ATOM_RENDERER_ATOM_RENDERER_CLIENT_H_