OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/browser/ui/browser_window_state.h" | 5 #include "chrome/browser/ui/browser_window_state.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "base/string_number_conversions.h" | 8 #include "base/string_number_conversions.h" |
9 #include "chrome/browser/defaults.h" | 9 #include "chrome/browser/defaults.h" |
10 #include "chrome/browser/prefs/pref_service.h" | 10 #include "chrome/browser/prefs/pref_service.h" |
(...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
73 // Save to the session storage service, used when reloading a past session. | 73 // Save to the session storage service, used when reloading a past session. |
74 // Note that we don't want to be the ones who cause lazy initialization of | 74 // Note that we don't want to be the ones who cause lazy initialization of |
75 // the session service. This function gets called during initial window | 75 // the session service. This function gets called during initial window |
76 // showing, and we don't want to bring in the session service this early. | 76 // showing, and we don't want to bring in the session service this early. |
77 SessionService* session_service = | 77 SessionService* session_service = |
78 SessionServiceFactory::GetForProfileIfExisting(browser->profile()); | 78 SessionServiceFactory::GetForProfileIfExisting(browser->profile()); |
79 if (session_service) | 79 if (session_service) |
80 session_service->SetWindowBounds(browser->session_id(), bounds, show_state); | 80 session_service->SetWindowBounds(browser->session_id(), bounds, show_state); |
81 } | 81 } |
82 | 82 |
83 gfx::Rect GetSavedWindowBounds(const Browser* browser) { | 83 gfx::Rect GetSavedWindowBoundsAndShowState(const Browser* browser, |
| 84 ui::WindowShowState& show_state) { |
84 gfx::Rect restored_bounds = browser->override_bounds(); | 85 gfx::Rect restored_bounds = browser->override_bounds(); |
85 WindowSizer::GetBrowserWindowBounds(browser->app_name(), | 86 WindowSizer::GetBrowserWindowBoundsAndShowState(browser->app_name(), |
86 restored_bounds, | 87 restored_bounds, |
87 browser, | 88 browser, |
88 &restored_bounds); | 89 &restored_bounds, |
| 90 show_state); |
89 | 91 |
90 const CommandLine& parsed_command_line = *CommandLine::ForCurrentProcess(); | 92 const CommandLine& parsed_command_line = *CommandLine::ForCurrentProcess(); |
91 bool record_mode = parsed_command_line.HasSwitch(switches::kRecordMode); | 93 bool record_mode = parsed_command_line.HasSwitch(switches::kRecordMode); |
92 bool playback_mode = parsed_command_line.HasSwitch(switches::kPlaybackMode); | 94 bool playback_mode = parsed_command_line.HasSwitch(switches::kPlaybackMode); |
93 if (record_mode || playback_mode) { | 95 if (record_mode || playback_mode) { |
94 // In playback/record mode we always fix the size of the browser and | 96 // In playback/record mode we always fix the size of the browser and |
95 // move it to (0,0). The reason for this is two reasons: First we want | 97 // move it to (0,0). The reason for this is two reasons: First we want |
96 // resize/moves in the playback to still work, and Second we want | 98 // resize/moves in the playback to still work, and Second we want |
97 // playbacks to work (as much as possible) on machines w/ different | 99 // playbacks to work (as much as possible) on machines w/ different |
98 // screen sizes. | 100 // screen sizes. |
(...skipping 12 matching lines...) Expand all Loading... |
111 std::string str = | 113 std::string str = |
112 parsed_command_line.GetSwitchValueASCII(switches::kWindowPosition); | 114 parsed_command_line.GetSwitchValueASCII(switches::kWindowPosition); |
113 int x, y; | 115 int x, y; |
114 if (ParseCommaSeparatedIntegers(str, &x, &y)) | 116 if (ParseCommaSeparatedIntegers(str, &x, &y)) |
115 restored_bounds.set_origin(gfx::Point(x, y)); | 117 restored_bounds.set_origin(gfx::Point(x, y)); |
116 } | 118 } |
117 | 119 |
118 return restored_bounds; | 120 return restored_bounds; |
119 } | 121 } |
120 | 122 |
121 ui::WindowShowState GetSavedWindowShowState(const Browser* browser) { | |
122 // Only tabbed browsers use the command line or preference state, with the | |
123 // exception of devtools. | |
124 bool show_state = !browser->is_type_tabbed() && !browser->is_devtools(); | |
125 | |
126 #if defined(USE_AURA) | |
127 // Apps save state on aura. | |
128 show_state &= !browser->is_app(); | |
129 #endif | |
130 | |
131 if (show_state) | |
132 return browser->initial_show_state(); | |
133 | |
134 if (CommandLine::ForCurrentProcess()->HasSwitch(switches::kStartMaximized)) | |
135 return ui::SHOW_STATE_MAXIMIZED; | |
136 | |
137 if (browser->initial_show_state() != ui::SHOW_STATE_DEFAULT) | |
138 return browser->initial_show_state(); | |
139 | |
140 const DictionaryValue* window_pref = browser->profile()->GetPrefs()-> | |
141 GetDictionary(GetWindowPlacementKey(browser).c_str()); | |
142 bool maximized = false; | |
143 window_pref->GetBoolean("maximized", &maximized); | |
144 | |
145 return maximized ? ui::SHOW_STATE_MAXIMIZED : ui::SHOW_STATE_DEFAULT; | |
146 } | |
147 | |
148 } // namespace chrome | 123 } // namespace chrome |
OLD | NEW |