Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1979)

Unified Diff: chrome/browser/guest_view/guest_view_base.cc

Issue 306003002: Move guest lifetime management to chrome (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fixed content_browsertests crash Created 6 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome/browser/guest_view/guest_view_base.h ('k') | chrome/browser/guest_view/web_view/web_view_guest.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/guest_view/guest_view_base.cc
diff --git a/chrome/browser/guest_view/guest_view_base.cc b/chrome/browser/guest_view/guest_view_base.cc
index 12f62c5ccb01fa6df1cfedfcb1d405758dc19318..122833cd63eb067971eea24bf36f2e5e4e29af2c 100644
--- a/chrome/browser/guest_view/guest_view_base.cc
+++ b/chrome/browser/guest_view/guest_view_base.cc
@@ -40,10 +40,35 @@ scoped_ptr<base::DictionaryValue> GuestViewBase::Event::GetArguments() {
return args_.Pass();
}
+// This observer ensures that the GuestViewBase destroys itself when its
+// embedder goes away.
+class GuestViewBase::EmbedderWebContentsObserver : public WebContentsObserver {
+ public:
+ explicit EmbedderWebContentsObserver(GuestViewBase* guest)
+ : WebContentsObserver(guest->embedder_web_contents()),
+ guest_(guest) {
+ }
+
+ virtual ~EmbedderWebContentsObserver() {
+ }
+
+ // WebContentsObserver implementation.
+ virtual void WebContentsDestroyed() OVERRIDE {
+ guest_->embedder_web_contents_ = NULL;
+ guest_->EmbedderDestroyed();
+ guest_->Destroy();
+ }
+
+ private:
+ GuestViewBase* guest_;
+
+ DISALLOW_COPY_AND_ASSIGN(EmbedderWebContentsObserver);
+};
+
GuestViewBase::GuestViewBase(int guest_instance_id,
WebContents* guest_web_contents,
const std::string& embedder_extension_id)
- : guest_web_contents_(guest_web_contents),
+ : WebContentsObserver(guest_web_contents),
embedder_web_contents_(NULL),
embedder_extension_id_(embedder_extension_id),
embedder_render_process_id_(0),
@@ -155,6 +180,8 @@ base::WeakPtr<GuestViewBase> GuestViewBase::AsWeakPtr() {
void GuestViewBase::Attach(content::WebContents* embedder_web_contents,
const base::DictionaryValue& args) {
embedder_web_contents_ = embedder_web_contents;
+ embedder_web_contents_observer_.reset(
+ new EmbedderWebContentsObserver(this));
embedder_render_process_id_ =
embedder_web_contents->GetRenderProcessHost()->GetID();
args.GetInteger(guestview::kParameterInstanceId, &view_instance_id_);
@@ -178,7 +205,7 @@ void GuestViewBase::Attach(content::WebContents* embedder_web_contents,
void GuestViewBase::Destroy() {
if (!destruction_callback_.is_null())
- destruction_callback_.Run(guest_web_contents());
+ destruction_callback_.Run();
delete guest_web_contents();
}
@@ -196,6 +223,10 @@ void GuestViewBase::RegisterDestructionCallback(
destruction_callback_ = callback;
}
+void GuestViewBase::WebContentsDestroyed() {
+ delete this;
+}
+
bool GuestViewBase::ShouldFocusPageAfterCrash() {
// Focus is managed elsewhere.
return false;
« no previous file with comments | « chrome/browser/guest_view/guest_view_base.h ('k') | chrome/browser/guest_view/web_view/web_view_guest.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698