From 71c7885ed81d49cb044498cd0f07db700b390655 Mon Sep 17 00:00:00 2001 From: "beng@google.com" Date: Mon, 8 Sep 2008 00:45:31 +0000 Subject: Make sure the browser is destroyed during DestroyBrowser because EndSession handling needs it to be synchronously deleted, rather than by the Window's destruction. B=1031854 Review URL: http://codereview.chromium.org/452 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@1832 0039d316-1c4b-4281-b951-d872f2087c98 --- chrome/browser/views/frame/browser_view2.cc | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) (limited to 'chrome/browser/views') diff --git a/chrome/browser/views/frame/browser_view2.cc b/chrome/browser/views/frame/browser_view2.cc index 64c210d..31259b7 100644 --- a/chrome/browser/views/frame/browser_view2.cc +++ b/chrome/browser/views/frame/browser_view2.cc @@ -438,6 +438,11 @@ void BrowserView2::FocusToolbar() { } void BrowserView2::DestroyBrowser() { + // Explicitly delete the BookmarkBarView now. That way we don't have to + // worry about the BookmarkBarView potentially outliving the Browser & + // Profile. + bookmark_bar_view_.reset(); + browser_.reset(); } bool BrowserView2::IsBookmarkBarVisible() const { @@ -472,7 +477,10 @@ void BrowserView2::Observe(NotificationType type, // BrowserView2, TabStripModelObserver implementation: void BrowserView2::TabDetachedAt(TabContents* contents, int index) { - if (contents == browser_->GetSelectedTabContents()) { + // We use index here rather than comparing |contents| because by this time + // the model has already removed |contents| from its list, so + // browser_->GetSelectedTabContents() will return NULL or something else. + if (index == browser_->tabstrip_model()->selected_index()) { // We need to reset the current tab contents to NULL before it gets // freed. This is because the focus manager performs some operations // on the selected TabContents when it is removed. -- cgit v1.1