OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "extensions/shell/browser/shell_browser_main_parts.h" | 5 #include "extensions/shell/browser/shell_browser_main_parts.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "base/run_loop.h" | 8 #include "base/run_loop.h" |
9 #include "components/keyed_service/content/browser_context_dependency_manager.h" | 9 #include "components/keyed_service/content/browser_context_dependency_manager.h" |
10 #include "components/omaha_query_params/omaha_query_params.h" | 10 #include "components/omaha_query_params/omaha_query_params.h" |
(...skipping 15 matching lines...) Expand all Loading... |
26 #include "extensions/shell/browser/shell_extension_system_factory.h" | 26 #include "extensions/shell/browser/shell_extension_system_factory.h" |
27 #include "extensions/shell/browser/shell_extensions_browser_client.h" | 27 #include "extensions/shell/browser/shell_extensions_browser_client.h" |
28 #include "extensions/shell/browser/shell_oauth2_token_service.h" | 28 #include "extensions/shell/browser/shell_oauth2_token_service.h" |
29 #include "extensions/shell/browser/shell_omaha_query_params_delegate.h" | 29 #include "extensions/shell/browser/shell_omaha_query_params_delegate.h" |
30 #include "extensions/shell/common/shell_extensions_client.h" | 30 #include "extensions/shell/common/shell_extensions_client.h" |
31 #include "extensions/shell/common/switches.h" | 31 #include "extensions/shell/common/switches.h" |
32 #include "ui/aura/env.h" | 32 #include "ui/aura/env.h" |
33 #include "ui/aura/window_tree_host.h" | 33 #include "ui/aura/window_tree_host.h" |
34 #include "ui/base/ime/input_method_initializer.h" | 34 #include "ui/base/ime/input_method_initializer.h" |
35 #include "ui/base/resource/resource_bundle.h" | 35 #include "ui/base/resource/resource_bundle.h" |
| 36 #include "ui/wm/core/user_activity_detector.h" |
36 | 37 |
37 #if !defined(OS_ANDROID) && !defined(OS_IOS) | 38 #if !defined(OS_ANDROID) && !defined(OS_IOS) |
38 #include "components/storage_monitor/storage_monitor.h" | 39 #include "components/storage_monitor/storage_monitor.h" |
39 #endif | 40 #endif |
40 | 41 |
41 #if defined(OS_CHROMEOS) | 42 #if defined(OS_CHROMEOS) |
42 #include "chromeos/audio/cras_audio_handler.h" | 43 #include "chromeos/audio/cras_audio_handler.h" |
43 #include "chromeos/dbus/dbus_thread_manager.h" | 44 #include "chromeos/dbus/dbus_thread_manager.h" |
44 #include "chromeos/network/network_handler.h" | 45 #include "chromeos/network/network_handler.h" |
45 #include "extensions/shell/browser/shell_audio_controller_chromeos.h" | 46 #include "extensions/shell/browser/shell_audio_controller_chromeos.h" |
(...skipping 71 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
117 void ShellBrowserMainParts::PreMainMessageLoopRun() { | 118 void ShellBrowserMainParts::PreMainMessageLoopRun() { |
118 // Initialize our "profile" equivalent. | 119 // Initialize our "profile" equivalent. |
119 browser_context_.reset(new ShellBrowserContext(net_log_.get())); | 120 browser_context_.reset(new ShellBrowserContext(net_log_.get())); |
120 | 121 |
121 aura::Env::GetInstance()->set_context_factory(content::GetContextFactory()); | 122 aura::Env::GetInstance()->set_context_factory(content::GetContextFactory()); |
122 | 123 |
123 #if !defined(OS_ANDROID) && !defined(OS_IOS) | 124 #if !defined(OS_ANDROID) && !defined(OS_IOS) |
124 storage_monitor::StorageMonitor::Create(); | 125 storage_monitor::StorageMonitor::Create(); |
125 #endif | 126 #endif |
126 | 127 |
| 128 // UserActivityDetector must be created prior to |desktop_controller_|. |
| 129 wm::UserActivityDetector::Create(); |
| 130 |
127 desktop_controller_.reset(browser_main_delegate_->CreateDesktopController()); | 131 desktop_controller_.reset(browser_main_delegate_->CreateDesktopController()); |
128 | 132 |
129 // NOTE: Much of this is culled from chrome/test/base/chrome_test_suite.cc | 133 // NOTE: Much of this is culled from chrome/test/base/chrome_test_suite.cc |
130 // TODO(jamescook): Initialize user_manager::UserManager. | 134 // TODO(jamescook): Initialize user_manager::UserManager. |
131 net_log_.reset(new content::ShellNetLog("app_shell")); | 135 net_log_.reset(new content::ShellNetLog("app_shell")); |
132 | 136 |
133 device_client_.reset(new ShellDeviceClient); | 137 device_client_.reset(new ShellDeviceClient); |
134 | 138 |
135 extensions_client_.reset(new ShellExtensionsClient()); | 139 extensions_client_.reset(new ShellExtensionsClient()); |
136 ExtensionsClient::Set(extensions_client_.get()); | 140 ExtensionsClient::Set(extensions_client_.get()); |
(...skipping 71 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
208 oauth2_token_service_.reset(); | 212 oauth2_token_service_.reset(); |
209 BrowserContextDependencyManager::GetInstance()->DestroyBrowserContextServices( | 213 BrowserContextDependencyManager::GetInstance()->DestroyBrowserContextServices( |
210 browser_context_.get()); | 214 browser_context_.get()); |
211 extension_system_ = NULL; | 215 extension_system_ = NULL; |
212 ExtensionsBrowserClient::Set(NULL); | 216 ExtensionsBrowserClient::Set(NULL); |
213 extensions_browser_client_.reset(); | 217 extensions_browser_client_.reset(); |
214 browser_context_.reset(); | 218 browser_context_.reset(); |
215 | 219 |
216 desktop_controller_.reset(); | 220 desktop_controller_.reset(); |
217 | 221 |
| 222 wm::UserActivityDetector::Shutdown(); |
| 223 |
218 #if !defined(OS_ANDROID) && !defined(OS_IOS) | 224 #if !defined(OS_ANDROID) && !defined(OS_IOS) |
219 storage_monitor::StorageMonitor::Destroy(); | 225 storage_monitor::StorageMonitor::Destroy(); |
220 #endif | 226 #endif |
221 } | 227 } |
222 | 228 |
223 void ShellBrowserMainParts::PostDestroyThreads() { | 229 void ShellBrowserMainParts::PostDestroyThreads() { |
224 #if defined(OS_CHROMEOS) | 230 #if defined(OS_CHROMEOS) |
225 audio_controller_.reset(); | 231 audio_controller_.reset(); |
226 chromeos::CrasAudioHandler::Shutdown(); | 232 chromeos::CrasAudioHandler::Shutdown(); |
227 network_controller_.reset(); | 233 network_controller_.reset(); |
228 chromeos::NetworkHandler::Shutdown(); | 234 chromeos::NetworkHandler::Shutdown(); |
229 chromeos::DBusThreadManager::Shutdown(); | 235 chromeos::DBusThreadManager::Shutdown(); |
230 #endif | 236 #endif |
231 } | 237 } |
232 | 238 |
233 void ShellBrowserMainParts::CreateExtensionSystem() { | 239 void ShellBrowserMainParts::CreateExtensionSystem() { |
234 DCHECK(browser_context_); | 240 DCHECK(browser_context_); |
235 extension_system_ = static_cast<ShellExtensionSystem*>( | 241 extension_system_ = static_cast<ShellExtensionSystem*>( |
236 ExtensionSystem::Get(browser_context_.get())); | 242 ExtensionSystem::Get(browser_context_.get())); |
237 extension_system_->InitForRegularProfile(true); | 243 extension_system_->InitForRegularProfile(true); |
238 } | 244 } |
239 | 245 |
240 } // namespace extensions | 246 } // namespace extensions |
OLD | NEW |