summaryrefslogtreecommitdiffstats
path: root/apps/shell
diff options
context:
space:
mode:
authorsky@chromium.org <sky@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2014-03-04 20:32:15 +0000
committersky@chromium.org <sky@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2014-03-04 20:32:15 +0000
commit97888a3981f3bb3f21c107eaf06a891893e13eaa (patch)
tree8ec47feb663f36a49d360e7f25a50ba2a5269426 /apps/shell
parent4f76cc113f90bc01d5df4f66dc32cab684b0336d (diff)
downloadchromium_src-97888a3981f3bb3f21c107eaf06a891893e13eaa.zip
chromium_src-97888a3981f3bb3f21c107eaf06a891893e13eaa.tar.gz
chromium_src-97888a3981f3bb3f21c107eaf06a891893e13eaa.tar.bz2
Plumbs through RenderFrameObserver::WillReleaseScriptContext
BUG=none TEST=none R=darin@chromium.org Review URL: https://codereview.chromium.org/185713008 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@254810 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'apps/shell')
-rw-r--r--apps/shell/renderer/shell_content_renderer_client.cc49
-rw-r--r--apps/shell/renderer/shell_content_renderer_client.h3
2 files changed, 42 insertions, 10 deletions
diff --git a/apps/shell/renderer/shell_content_renderer_client.cc b/apps/shell/renderer/shell_content_renderer_client.cc
index 4e437cc..71cf442 100644
--- a/apps/shell/renderer/shell_content_renderer_client.cc
+++ b/apps/shell/renderer/shell_content_renderer_client.cc
@@ -7,6 +7,9 @@
#include "apps/shell/common/shell_extensions_client.h"
#include "chrome/renderer/extensions/dispatcher.h"
#include "chrome/renderer/extensions/extension_helper.h"
+#include "content/public/renderer/render_frame.h"
+#include "content/public/renderer/render_frame_observer.h"
+#include "content/public/renderer/render_frame_observer_tracker.h"
#include "content/public/renderer/render_thread.h"
#include "extensions/common/extensions_client.h"
@@ -16,6 +19,43 @@ using content::RenderThread;
namespace apps {
+namespace {
+
+// TODO: promote ExtensionFrameHelper to a common place and share with this.
+class ShellFrameHelper
+ : public content::RenderFrameObserver,
+ public content::RenderFrameObserverTracker<ShellFrameHelper> {
+ public:
+ ShellFrameHelper(content::RenderFrame* render_frame,
+ extensions::Dispatcher* extension_dispatcher);
+ virtual ~ShellFrameHelper();
+
+ // RenderFrameObserver implementation.
+ virtual void WillReleaseScriptContext(v8::Handle<v8::Context>,
+ int world_id) OVERRIDE;
+
+ private:
+ extensions::Dispatcher* extension_dispatcher_;
+
+ DISALLOW_COPY_AND_ASSIGN(ShellFrameHelper);
+};
+
+ShellFrameHelper::ShellFrameHelper(content::RenderFrame* render_frame,
+ extensions::Dispatcher* extension_dispatcher)
+ : content::RenderFrameObserver(render_frame),
+ content::RenderFrameObserverTracker<ShellFrameHelper>(render_frame),
+ extension_dispatcher_(extension_dispatcher) {}
+
+ShellFrameHelper::~ShellFrameHelper() {}
+
+void ShellFrameHelper::WillReleaseScriptContext(v8::Handle<v8::Context> context,
+ int world_id) {
+ extension_dispatcher_->WillReleaseScriptContext(
+ render_frame()->GetWebFrame(), context, world_id);
+}
+
+} // namespace
+
ShellContentRendererClient::ShellContentRendererClient() {}
ShellContentRendererClient::~ShellContentRendererClient() {}
@@ -35,8 +75,8 @@ void ShellContentRendererClient::RenderThreadStarted() {
void ShellContentRendererClient::RenderFrameCreated(
content::RenderFrame* render_frame) {
- // TODO(jamescook): Create ExtensionFrameHelper? This might be needed for
- // Pepper plugins like Flash.
+ // ShellFrameHelper destroyes itself when the RenderFrame is destroyed.
+ new ShellFrameHelper(render_frame, extension_dispatcher_.get());
}
void ShellContentRendererClient::RenderViewCreated(
@@ -61,11 +101,6 @@ void ShellContentRendererClient::DidCreateScriptContext(
frame, context, extension_group, world_id);
}
-void ShellContentRendererClient::WillReleaseScriptContext(
- WebFrame* frame, v8::Handle<v8::Context> context, int world_id) {
- extension_dispatcher_->WillReleaseScriptContext(frame, context, world_id);
-}
-
bool ShellContentRendererClient::ShouldEnableSiteIsolationPolicy() const {
// Extension renderers don't need site isolation.
return false;
diff --git a/apps/shell/renderer/shell_content_renderer_client.h b/apps/shell/renderer/shell_content_renderer_client.h
index 12f9538..4f31225 100644
--- a/apps/shell/renderer/shell_content_renderer_client.h
+++ b/apps/shell/renderer/shell_content_renderer_client.h
@@ -37,9 +37,6 @@ class ShellContentRendererClient : public content::ContentRendererClient {
v8::Handle<v8::Context> context,
int extension_group,
int world_id) OVERRIDE;
- virtual void WillReleaseScriptContext(blink::WebFrame* frame,
- v8::Handle<v8::Context> context,
- int world_id) OVERRIDE;
virtual bool ShouldEnableSiteIsolationPolicy() const OVERRIDE;
private: