| OLD | NEW | 
|---|
| 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 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/browser_process_impl.h" | 5 #include "chrome/browser/browser_process_impl.h" | 
| 6 | 6 | 
| 7 #include <map> | 7 #include <map> | 
| 8 | 8 | 
| 9 #include "app/clipboard/clipboard.h" | 9 #include "app/clipboard/clipboard.h" | 
| 10 #include "app/l10n_util.h" | 10 #include "app/l10n_util.h" | 
| (...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 49 #include "chrome/browser/tab_closeable_state_watcher.h" | 49 #include "chrome/browser/tab_closeable_state_watcher.h" | 
| 50 #include "chrome/common/chrome_constants.h" | 50 #include "chrome/common/chrome_constants.h" | 
| 51 #include "chrome/common/chrome_paths.h" | 51 #include "chrome/common/chrome_paths.h" | 
| 52 #include "chrome/common/chrome_switches.h" | 52 #include "chrome/common/chrome_switches.h" | 
| 53 #include "chrome/common/extensions/extension_resource.h" | 53 #include "chrome/common/extensions/extension_resource.h" | 
| 54 #include "chrome/common/extensions/extension_l10n_util.h" | 54 #include "chrome/common/extensions/extension_l10n_util.h" | 
| 55 #include "chrome/common/json_pref_store.h" | 55 #include "chrome/common/json_pref_store.h" | 
| 56 #include "chrome/common/notification_service.h" | 56 #include "chrome/common/notification_service.h" | 
| 57 #include "chrome/common/pref_names.h" | 57 #include "chrome/common/pref_names.h" | 
| 58 #include "chrome/common/url_constants.h" | 58 #include "chrome/common/url_constants.h" | 
|  | 59 #include "chrome/common/switch_utils.h" | 
| 59 #include "chrome/installer/util/google_update_constants.h" | 60 #include "chrome/installer/util/google_update_constants.h" | 
| 60 #include "ipc/ipc_logging.h" | 61 #include "ipc/ipc_logging.h" | 
| 61 #include "webkit/database/database_tracker.h" | 62 #include "webkit/database/database_tracker.h" | 
| 62 | 63 | 
| 63 #if defined(OS_WIN) | 64 #if defined(OS_WIN) | 
| 64 #include "views/focus/view_storage.h" | 65 #include "views/focus/view_storage.h" | 
| 65 #endif | 66 #endif | 
| 66 | 67 | 
| 67 #if defined(IPC_MESSAGE_LOG_ENABLED) | 68 #if defined(IPC_MESSAGE_LOG_ENABLED) | 
| 68 #include "chrome/common/plugin_messages.h" | 69 #include "chrome/common/plugin_messages.h" | 
| (...skipping 678 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 747 // Mac is currently not supported. | 748 // Mac is currently not supported. | 
| 748 #if (defined(OS_WIN) || defined(OS_LINUX)) && !defined(OS_CHROMEOS) | 749 #if (defined(OS_WIN) || defined(OS_LINUX)) && !defined(OS_CHROMEOS) | 
| 749 | 750 | 
| 750 bool BrowserProcessImpl::CanAutorestartForUpdate() const { | 751 bool BrowserProcessImpl::CanAutorestartForUpdate() const { | 
| 751   // Check if browser is in the background and if it needs to be restarted to | 752   // Check if browser is in the background and if it needs to be restarted to | 
| 752   // apply a pending update. | 753   // apply a pending update. | 
| 753   return BrowserList::size() == 0 && BrowserList::WillKeepAlive() && | 754   return BrowserList::size() == 0 && BrowserList::WillKeepAlive() && | 
| 754          Upgrade::IsUpdatePendingRestart(); | 755          Upgrade::IsUpdatePendingRestart(); | 
| 755 } | 756 } | 
| 756 | 757 | 
| 757 // Switches enumerated here will be removed when a background instance of | 758 // Switches to add when auto-restarting Chrome. | 
| 758 // Chrome restarts itself. If your key is designed to only be used once, |  | 
| 759 // or if it does not make sense when restarting a background instance to |  | 
| 760 // pick up an automatic update, be sure to add it to this list. |  | 
| 761 const char* const kSwitchesToRemoveOnAutorestart[] = { |  | 
| 762   switches::kApp, |  | 
| 763   switches::kFirstRun, |  | 
| 764   switches::kImport, |  | 
| 765   switches::kImportFromFile, |  | 
| 766   switches::kMakeDefaultBrowser |  | 
| 767 }; |  | 
| 768 |  | 
| 769 const char* const kSwitchesToAddOnAutorestart[] = { | 759 const char* const kSwitchesToAddOnAutorestart[] = { | 
| 770   switches::kNoStartupWindow | 760   switches::kNoStartupWindow | 
| 771 }; | 761 }; | 
| 772 | 762 | 
| 773 void BrowserProcessImpl::RestartPersistentInstance() { | 763 void BrowserProcessImpl::RestartPersistentInstance() { | 
| 774   CommandLine* old_cl = CommandLine::ForCurrentProcess(); | 764   CommandLine* old_cl = CommandLine::ForCurrentProcess(); | 
| 775   scoped_ptr<CommandLine> new_cl(new CommandLine(old_cl->GetProgram())); | 765   scoped_ptr<CommandLine> new_cl(new CommandLine(old_cl->GetProgram())); | 
| 776 | 766 | 
| 777   std::map<std::string, CommandLine::StringType> switches = | 767   std::map<std::string, CommandLine::StringType> switches = | 
| 778       old_cl->GetSwitches(); | 768       old_cl->GetSwitches(); | 
| 779 | 769 | 
| 780   // Remove the keys that we shouldn't pass through during restart. | 770   switches::RemoveSwitchesForAutostart(&switches); | 
| 781   for (size_t i = 0; i < arraysize(kSwitchesToRemoveOnAutorestart); i++) { |  | 
| 782     switches.erase(kSwitchesToRemoveOnAutorestart[i]); |  | 
| 783   } |  | 
| 784 | 771 | 
| 785   // Append the rest of the switches (along with their values, if any) | 772   // Append the rest of the switches (along with their values, if any) | 
| 786   // to the new command line | 773   // to the new command line | 
| 787   for (std::map<std::string, CommandLine::StringType>::const_iterator i = | 774   for (std::map<std::string, CommandLine::StringType>::const_iterator i = | 
| 788       switches.begin(); i != switches.end(); ++i) { | 775       switches.begin(); i != switches.end(); ++i) { | 
| 789       CommandLine::StringType switch_value = i->second; | 776       CommandLine::StringType switch_value = i->second; | 
| 790       if (switch_value.length() > 0) { | 777       if (switch_value.length() > 0) { | 
| 791         new_cl->AppendSwitchNative(i->first, i->second); | 778         new_cl->AppendSwitchNative(i->first, i->second); | 
| 792       } else { | 779       } else { | 
| 793         new_cl->AppendSwitch(i->first); | 780         new_cl->AppendSwitch(i->first); | 
| 794       } | 781       } | 
| 795   } | 782   } | 
| 796 | 783 | 
| 797   // Ensure that our desired switches are set on the new process. | 784   // Ensure that our desired switches are set on the new process. | 
| 798   for (size_t i = 0; i < arraysize(kSwitchesToAddOnAutorestart); i++) { | 785   for (size_t i = 0; i < arraysize(kSwitchesToAddOnAutorestart); ++i) { | 
| 799     if (!new_cl->HasSwitch(kSwitchesToAddOnAutorestart[i])) | 786     if (!new_cl->HasSwitch(kSwitchesToAddOnAutorestart[i])) | 
| 800       new_cl->AppendSwitch(kSwitchesToAddOnAutorestart[i]); | 787       new_cl->AppendSwitch(kSwitchesToAddOnAutorestart[i]); | 
| 801   } | 788   } | 
| 802 | 789 | 
| 803   DLOG(WARNING) << "Shutting down current instance of the browser."; | 790   DLOG(WARNING) << "Shutting down current instance of the browser."; | 
| 804   BrowserList::CloseAllBrowsersAndExit(); | 791   BrowserList::CloseAllBrowsersAndExit(); | 
| 805 | 792 | 
| 806   // Transfer ownership to Upgrade. | 793   // Transfer ownership to Upgrade. | 
| 807   Upgrade::SetNewCommandLine(new_cl.release()); | 794   Upgrade::SetNewCommandLine(new_cl.release()); | 
| 808 } | 795 } | 
| 809 | 796 | 
| 810 void BrowserProcessImpl::OnAutoupdateTimer() { | 797 void BrowserProcessImpl::OnAutoupdateTimer() { | 
| 811   if (CanAutorestartForUpdate()) { | 798   if (CanAutorestartForUpdate()) { | 
| 812     DLOG(WARNING) << "Detected update.  Restarting browser."; | 799     DLOG(WARNING) << "Detected update.  Restarting browser."; | 
| 813     RestartPersistentInstance(); | 800     RestartPersistentInstance(); | 
| 814   } | 801   } | 
| 815 } | 802 } | 
| 816 | 803 | 
| 817 #endif  // (defined(OS_WIN) || defined(OS_LINUX)) && !defined(OS_CHROMEOS) | 804 #endif  // (defined(OS_WIN) || defined(OS_LINUX)) && !defined(OS_CHROMEOS) | 
| OLD | NEW | 
|---|