diff options
author | sky@google.com <sky@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-03-09 21:11:01 +0000 |
---|---|---|
committer | sky@google.com <sky@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-03-09 21:11:01 +0000 |
commit | 2e71662080eac468322f9b61a81a3abb4c9d40bc (patch) | |
tree | 863408b851a33c57eeedd3bc788f1f8416a2ec02 | |
parent | 8bf80e9295fcc8166e103d3f4a5d1947619c525c (diff) | |
download | chromium_src-2e71662080eac468322f9b61a81a3abb4c9d40bc.zip chromium_src-2e71662080eac468322f9b61a81a3abb4c9d40bc.tar.gz chromium_src-2e71662080eac468322f9b61a81a3abb4c9d40bc.tar.bz2 |
Fixes session restore bug where we wouldn't necessarily correctly
restore the maximized state. The problem was we were using a boolean
when we really needed three values: use the default, explicitly
maximized or explicitly normal.
I'm also removing a bogus DLOG in info_bubble.
BUG=7930
TEST=see bug
Review URL: http://codereview.chromium.org/40306
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@11287 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | chrome/browser/browser.cc | 13 | ||||
-rw-r--r-- | chrome/browser/browser.h | 19 | ||||
-rw-r--r-- | chrome/browser/sessions/session_restore.cc | 4 | ||||
-rw-r--r-- | chrome/browser/views/info_bubble.cc | 1 |
4 files changed, 29 insertions, 8 deletions
diff --git a/chrome/browser/browser.cc b/chrome/browser/browser.cc index 4e21329..4de2951 100644 --- a/chrome/browser/browser.cc +++ b/chrome/browser/browser.cc @@ -174,7 +174,7 @@ Browser::Browser(Type type, Profile* profile) toolbar_model_(this), chrome_updater_factory_(this), is_attempting_to_close_browser_(false), - override_maximized_(false), + maximized_state_(MAXIMIZED_STATE_DEFAULT), method_factory_(this), idle_task_(new BrowserIdleTimer) { tabstrip_model_.AddObserver(this); @@ -376,8 +376,14 @@ bool Browser::GetSavedMaximizedState() const { if (CommandLine::ForCurrentProcess()->HasSwitch(switches::kStartMaximized)) return true; + if (maximized_state_ == MAXIMIZED_STATE_MAXIMIZED) + return true; + if (maximized_state_ == MAXIMIZED_STATE_UNMAXIMIZED) + return false; + + // An explicit maximized state was not set. Query the window sizer. gfx::Rect restored_bounds; - bool maximized = override_maximized_; + bool maximized = false; WindowSizer::GetBrowserWindowBounds(app_name_, restored_bounds, &restored_bounds, &maximized); return maximized; @@ -1262,7 +1268,8 @@ void Browser::CreateNewStripWithContents(TabContents* detached_contents, // Create an empty new browser window the same size as the old one. Browser* browser = new Browser(TYPE_NORMAL, profile_); browser->set_override_bounds(new_window_bounds); - browser->set_override_maximized(maximize); + browser->set_maximized_state( + maximize ? MAXIMIZED_STATE_MAXIMIZED : MAXIMIZED_STATE_UNMAXIMIZED); browser->CreateBrowserWindow(); browser->tabstrip_model()->AppendTabContents(detached_contents, true); // Make sure the loading state is updated correctly, otherwise the throbber diff --git a/chrome/browser/browser.h b/chrome/browser/browser.h index 5efbec8..dc9ebbd 100644 --- a/chrome/browser/browser.h +++ b/chrome/browser/browser.h @@ -68,6 +68,19 @@ class Browser : public TabStripModelDelegate, FEATURE_DOWNLOADSHELF = 64 }; + // Maximized state on creation. + enum MaximizedState { + // The maximized state is set to the default, which varies depending upon + // what the user has done. + MAXIMIZED_STATE_DEFAULT, + + // Maximized state is explicitly maximized. + MAXIMIZED_STATE_MAXIMIZED, + + // Maximized state is explicitly not maximized (normal). + MAXIMIZED_STATE_UNMAXIMIZED + }; + // Constructors, Creation, Showing ////////////////////////////////////////// // Creates a new browser of the given |type| and for the given |profile|. The @@ -92,8 +105,8 @@ class Browser : public TabStripModelDelegate, void set_override_bounds(const gfx::Rect& bounds) { override_bounds_ = bounds; } - void set_override_maximized(bool maximized) { - override_maximized_ = maximized; + void set_maximized_state(MaximizedState state) { + maximized_state_ = state; } // Creates the Browser Window. Prefer to use the static helpers above where @@ -640,7 +653,7 @@ class Browser : public TabStripModelDelegate, // obtained from the last window of the same type, or obtained from the // shell shortcut's startup info. gfx::Rect override_bounds_; - bool override_maximized_; + MaximizedState maximized_state_; // The following factory is used to close the frame at a later time. ScopedRunnableMethodFactory<Browser> method_factory_; diff --git a/chrome/browser/sessions/session_restore.cc b/chrome/browser/sessions/session_restore.cc index b6db981..51c5403 100644 --- a/chrome/browser/sessions/session_restore.cc +++ b/chrome/browser/sessions/session_restore.cc @@ -300,7 +300,9 @@ class SessionRestoreImpl : public NotificationObserver { if (!browser) { browser = new Browser((*i)->type, profile_); browser->set_override_bounds((*i)->bounds); - browser->set_override_maximized((*i)->is_maximized); + browser->set_maximized_state((*i)->is_maximized ? + Browser::MAXIMIZED_STATE_MAXIMIZED : + Browser::MAXIMIZED_STATE_UNMAXIMIZED); browser->CreateBrowserWindow(); } if ((*i)->type == Browser::TYPE_NORMAL) diff --git a/chrome/browser/views/info_bubble.cc b/chrome/browser/views/info_bubble.cc index 8c030d6..8dbf410 100644 --- a/chrome/browser/views/info_bubble.cc +++ b/chrome/browser/views/info_bubble.cc @@ -71,7 +71,6 @@ InfoBubble* InfoBubble::Show(HWND parent_hwnd, views::View* content, InfoBubbleDelegate* delegate) { InfoBubble* window = new InfoBubble(); - DLOG(WARNING) << "new bubble=" << window; window->Init(parent_hwnd, position_relative_to, content); // Set the delegate before we show, on the off chance the delegate is needed // during showing. |