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/chrome_browser_main.h" | 5 #include "chrome/browser/chrome_browser_main.h" |
6 | 6 |
7 #if defined(TOOLKIT_GTK) | 7 #if defined(TOOLKIT_GTK) |
8 #include <gtk/gtk.h> | 8 #include <gtk/gtk.h> |
9 #endif | 9 #endif |
10 | 10 |
(...skipping 1078 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1089 // TODO(sky): nuke this when all ports support ActiveTabTracker. | 1089 // TODO(sky): nuke this when all ports support ActiveTabTracker. |
1090 if (!active_tab_tracker_->is_valid()) | 1090 if (!active_tab_tracker_->is_valid()) |
1091 active_tab_tracker_.reset(); | 1091 active_tab_tracker_.reset(); |
1092 } | 1092 } |
1093 #endif | 1093 #endif |
1094 | 1094 |
1095 // Android updates the metrics service dynamically depending on whether the | 1095 // Android updates the metrics service dynamically depending on whether the |
1096 // application is in the foreground or not. Do not start here. | 1096 // application is in the foreground or not. Do not start here. |
1097 #if !defined(OS_ANDROID) | 1097 #if !defined(OS_ANDROID) |
1098 // Now that the file thread has been started, start recording. | 1098 // Now that the file thread has been started, start recording. |
| 1099 MetricsService::SetExecutionPhase(MetricsService::START_METRICS_RECORDING); |
1099 StartMetricsRecording(); | 1100 StartMetricsRecording(); |
1100 #endif | 1101 #endif |
1101 | 1102 |
1102 // Create watchdog thread after creating all other threads because it will | 1103 // Create watchdog thread after creating all other threads because it will |
1103 // watch the other threads and they must be running. | 1104 // watch the other threads and they must be running. |
1104 browser_process_->watchdog_thread(); | 1105 browser_process_->watchdog_thread(); |
1105 | 1106 |
1106 // Do any initializating in the browser process that requires all threads | 1107 // Do any initializating in the browser process that requires all threads |
1107 // running. | 1108 // running. |
1108 browser_process_->PreMainMessageLoopRun(); | 1109 browser_process_->PreMainMessageLoopRun(); |
(...skipping 126 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1235 return content::RESULT_CODE_NORMAL_EXIT; | 1236 return content::RESULT_CODE_NORMAL_EXIT; |
1236 #endif // defined(OS_WIN) | 1237 #endif // defined(OS_WIN) |
1237 } | 1238 } |
1238 | 1239 |
1239 // Profile creation ---------------------------------------------------------- | 1240 // Profile creation ---------------------------------------------------------- |
1240 | 1241 |
1241 // Called before CreateProfile because creating the profile can trigger | 1242 // Called before CreateProfile because creating the profile can trigger |
1242 // calls to GetDefaultProfile(). | 1243 // calls to GetDefaultProfile(). |
1243 ProfileManager::AllowGetDefaultProfile(); | 1244 ProfileManager::AllowGetDefaultProfile(); |
1244 | 1245 |
| 1246 MetricsService::SetExecutionPhase(MetricsService::CREATE_PROFILE); |
1245 profile_ = CreateProfile(parameters(), user_data_dir_, parsed_command_line()); | 1247 profile_ = CreateProfile(parameters(), user_data_dir_, parsed_command_line()); |
1246 if (!profile_) | 1248 if (!profile_) |
1247 return content::RESULT_CODE_NORMAL_EXIT; | 1249 return content::RESULT_CODE_NORMAL_EXIT; |
1248 | 1250 |
1249 #if defined(ENABLE_BACKGROUND) | 1251 #if defined(ENABLE_BACKGROUND) |
1250 // Autoload any profiles which are running background apps. | 1252 // Autoload any profiles which are running background apps. |
1251 // TODO(rlp): Do this on a separate thread. See http://crbug.com/99075. | 1253 // TODO(rlp): Do this on a separate thread. See http://crbug.com/99075. |
1252 browser_process_->profile_manager()->AutoloadProfiles(); | 1254 browser_process_->profile_manager()->AutoloadProfiles(); |
1253 #endif | 1255 #endif |
1254 // Post-profile init --------------------------------------------------------- | 1256 // Post-profile init --------------------------------------------------------- |
(...skipping 164 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1419 extensions::StartupHelper extension_startup_helper; | 1421 extensions::StartupHelper extension_startup_helper; |
1420 if (extension_startup_helper.UninstallExtension( | 1422 if (extension_startup_helper.UninstallExtension( |
1421 parsed_command_line(), profile_)) | 1423 parsed_command_line(), profile_)) |
1422 return content::RESULT_CODE_NORMAL_EXIT; | 1424 return content::RESULT_CODE_NORMAL_EXIT; |
1423 return chrome::RESULT_CODE_UNINSTALL_EXTENSION_ERROR; | 1425 return chrome::RESULT_CODE_UNINSTALL_EXTENSION_ERROR; |
1424 } | 1426 } |
1425 | 1427 |
1426 // Start watching for hangs during startup. We disarm this hang detector when | 1428 // Start watching for hangs during startup. We disarm this hang detector when |
1427 // ThreadWatcher takes over or when browser is shutdown or when | 1429 // ThreadWatcher takes over or when browser is shutdown or when |
1428 // startup_watcher_ is deleted. | 1430 // startup_watcher_ is deleted. |
| 1431 MetricsService::SetExecutionPhase(MetricsService::STARTUP_TIMEBOMB_ARM); |
1429 startup_watcher_->Arm(base::TimeDelta::FromSeconds(300)); | 1432 startup_watcher_->Arm(base::TimeDelta::FromSeconds(300)); |
1430 | 1433 |
1431 // On mobile, need for clean shutdown arises only when the application comes | 1434 // On mobile, need for clean shutdown arises only when the application comes |
1432 // to foreground (i.e. MetricsService::OnAppEnterForeground is called). | 1435 // to foreground (i.e. MetricsService::OnAppEnterForeground is called). |
1433 // http://crbug.com/179143 | 1436 // http://crbug.com/179143 |
1434 #if !defined(OS_ANDROID) | 1437 #if !defined(OS_ANDROID) |
1435 // Start watching for a hang. | 1438 // Start watching for a hang. |
1436 MetricsService::LogNeedForCleanShutdown(); | 1439 MetricsService::LogNeedForCleanShutdown(); |
1437 #endif | 1440 #endif |
1438 | 1441 |
1439 #if defined(ENABLE_FULL_PRINTING) | 1442 #if defined(ENABLE_FULL_PRINTING) |
1440 // Create the instance of the cloud print proxy service so that it can launch | 1443 // Create the instance of the cloud print proxy service so that it can launch |
1441 // the service process if needed. This is needed because the service process | 1444 // the service process if needed. This is needed because the service process |
1442 // might have shutdown because an update was available. | 1445 // might have shutdown because an update was available. |
1443 // TODO(torne): this should maybe be done with | 1446 // TODO(torne): this should maybe be done with |
1444 // BrowserContextKeyedServiceFactory::ServiceIsCreatedWithBrowserContext() | 1447 // BrowserContextKeyedServiceFactory::ServiceIsCreatedWithBrowserContext() |
1445 // instead? | 1448 // instead? |
1446 CloudPrintProxyServiceFactory::GetForProfile(profile_); | 1449 CloudPrintProxyServiceFactory::GetForProfile(profile_); |
1447 #endif | 1450 #endif |
1448 | 1451 |
1449 // Start watching all browser threads for responsiveness. | 1452 // Start watching all browser threads for responsiveness. |
| 1453 MetricsService::SetExecutionPhase(MetricsService::THREAD_WATCHER_START); |
1450 ThreadWatcherList::StartWatchingAll(parsed_command_line()); | 1454 ThreadWatcherList::StartWatchingAll(parsed_command_line()); |
1451 | 1455 |
1452 #if !defined(DISABLE_NACL) | 1456 #if !defined(DISABLE_NACL) |
1453 if (parsed_command_line().HasSwitch(switches::kPnaclDir)) { | 1457 if (parsed_command_line().HasSwitch(switches::kPnaclDir)) { |
1454 PathService::Override(chrome::DIR_PNACL_BASE, | 1458 PathService::Override(chrome::DIR_PNACL_BASE, |
1455 parsed_command_line().GetSwitchValuePath( | 1459 parsed_command_line().GetSwitchValuePath( |
1456 switches::kPnaclDir)); | 1460 switches::kPnaclDir)); |
1457 } | 1461 } |
1458 | 1462 |
1459 content::BrowserThread::PostTask( | 1463 content::BrowserThread::PostTask( |
(...skipping 151 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1611 DCHECK_EQ(base::MessageLoop::TYPE_UI, base::MessageLoop::current()->type()); | 1615 DCHECK_EQ(base::MessageLoop::TYPE_UI, base::MessageLoop::current()->type()); |
1612 #if !defined(USE_AURA) && defined(TOOLKIT_VIEWS) | 1616 #if !defined(USE_AURA) && defined(TOOLKIT_VIEWS) |
1613 views::AcceleratorHandler accelerator_handler; | 1617 views::AcceleratorHandler accelerator_handler; |
1614 base::RunLoop run_loop(&accelerator_handler); | 1618 base::RunLoop run_loop(&accelerator_handler); |
1615 #else | 1619 #else |
1616 base::RunLoop run_loop; | 1620 base::RunLoop run_loop; |
1617 #endif | 1621 #endif |
1618 | 1622 |
1619 performance_monitor::PerformanceMonitor::GetInstance()->StartGatherCycle(); | 1623 performance_monitor::PerformanceMonitor::GetInstance()->StartGatherCycle(); |
1620 | 1624 |
| 1625 MetricsService::SetExecutionPhase(MetricsService::MAIN_MESSAGE_LOOP_RUN); |
1621 run_loop.Run(); | 1626 run_loop.Run(); |
1622 | 1627 |
1623 return true; | 1628 return true; |
1624 #endif | 1629 #endif |
1625 } | 1630 } |
1626 | 1631 |
1627 void ChromeBrowserMainParts::PostMainMessageLoopRun() { | 1632 void ChromeBrowserMainParts::PostMainMessageLoopRun() { |
1628 TRACE_EVENT0("startup", "ChromeBrowserMainParts::PostMainMessageLoopRun"); | 1633 TRACE_EVENT0("startup", "ChromeBrowserMainParts::PostMainMessageLoopRun"); |
1629 #if defined(OS_ANDROID) | 1634 #if defined(OS_ANDROID) |
1630 // Chrome on Android does not use default MessageLoop. It has its own | 1635 // Chrome on Android does not use default MessageLoop. It has its own |
1631 // Android specific MessageLoop | 1636 // Android specific MessageLoop |
1632 NOTREACHED(); | 1637 NOTREACHED(); |
1633 #else | 1638 #else |
1634 | 1639 |
1635 // Start watching for jank during shutdown. It gets disarmed when | 1640 // Start watching for jank during shutdown. It gets disarmed when |
1636 // |shutdown_watcher_| object is destructed. | 1641 // |shutdown_watcher_| object is destructed. |
| 1642 MetricsService::SetExecutionPhase(MetricsService::SHUTDOWN_TIMEBOMB_ARM); |
1637 shutdown_watcher_->Arm(base::TimeDelta::FromSeconds(300)); | 1643 shutdown_watcher_->Arm(base::TimeDelta::FromSeconds(300)); |
1638 | 1644 |
1639 // Disarm the startup hang detector time bomb if it is still Arm'ed. | 1645 // Disarm the startup hang detector time bomb if it is still Arm'ed. |
1640 startup_watcher_->Disarm(); | 1646 startup_watcher_->Disarm(); |
1641 | 1647 |
1642 for (size_t i = 0; i < chrome_extra_parts_.size(); ++i) | 1648 for (size_t i = 0; i < chrome_extra_parts_.size(); ++i) |
1643 chrome_extra_parts_[i]->PostMainMessageLoopRun(); | 1649 chrome_extra_parts_[i]->PostMainMessageLoopRun(); |
1644 | 1650 |
1645 // Some tests don't set parameters.ui_task, so they started translate | 1651 // Some tests don't set parameters.ui_task, so they started translate |
1646 // language fetch that was never completed so we need to cleanup here | 1652 // language fetch that was never completed so we need to cleanup here |
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1686 chromeos::CrosSettings::Shutdown(); | 1692 chromeos::CrosSettings::Shutdown(); |
1687 #endif | 1693 #endif |
1688 #endif | 1694 #endif |
1689 } | 1695 } |
1690 | 1696 |
1691 // Public members: | 1697 // Public members: |
1692 | 1698 |
1693 void ChromeBrowserMainParts::AddParts(ChromeBrowserMainExtraParts* parts) { | 1699 void ChromeBrowserMainParts::AddParts(ChromeBrowserMainExtraParts* parts) { |
1694 chrome_extra_parts_.push_back(parts); | 1700 chrome_extra_parts_.push_back(parts); |
1695 } | 1701 } |
OLD | NEW |