OLD | NEW |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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_init.h" | 5 #include "chrome/browser/ui/browser_init.h" |
6 | 6 |
7 #include <algorithm> // For max(). | 7 #include <algorithm> // For max(). |
8 | 8 |
9 #include "base/compiler_specific.h" | 9 #include "base/compiler_specific.h" |
10 #include "base/environment.h" | 10 #include "base/environment.h" |
(...skipping 22 matching lines...) Expand all Loading... |
33 #include "chrome/browser/platform_util.h" | 33 #include "chrome/browser/platform_util.h" |
34 #include "chrome/browser/prefs/pref_service.h" | 34 #include "chrome/browser/prefs/pref_service.h" |
35 #include "chrome/browser/prefs/session_startup_pref.h" | 35 #include "chrome/browser/prefs/session_startup_pref.h" |
36 #include "chrome/browser/printing/cloud_print/cloud_print_proxy_service.h" | 36 #include "chrome/browser/printing/cloud_print/cloud_print_proxy_service.h" |
37 #include "chrome/browser/printing/print_dialog_cloud.h" | 37 #include "chrome/browser/printing/print_dialog_cloud.h" |
38 #include "chrome/browser/profiles/profile.h" | 38 #include "chrome/browser/profiles/profile.h" |
39 #include "chrome/browser/search_engines/template_url.h" | 39 #include "chrome/browser/search_engines/template_url.h" |
40 #include "chrome/browser/search_engines/template_url_model.h" | 40 #include "chrome/browser/search_engines/template_url_model.h" |
41 #include "chrome/browser/sessions/session_restore.h" | 41 #include "chrome/browser/sessions/session_restore.h" |
42 #include "chrome/browser/sessions/session_service.h" | 42 #include "chrome/browser/sessions/session_service.h" |
| 43 #include "chrome/browser/sessions/session_service_factory.h" |
43 #include "chrome/browser/shell_integration.h" | 44 #include "chrome/browser/shell_integration.h" |
44 #include "chrome/browser/tab_contents/confirm_infobar_delegate.h" | 45 #include "chrome/browser/tab_contents/confirm_infobar_delegate.h" |
45 #include "chrome/browser/tab_contents/simple_alert_infobar_delegate.h" | 46 #include "chrome/browser/tab_contents/simple_alert_infobar_delegate.h" |
46 #include "chrome/browser/tabs/pinned_tab_codec.h" | 47 #include "chrome/browser/tabs/pinned_tab_codec.h" |
47 #include "chrome/browser/tabs/tab_strip_model.h" | 48 #include "chrome/browser/tabs/tab_strip_model.h" |
48 #include "chrome/browser/ui/browser_list.h" | 49 #include "chrome/browser/ui/browser_list.h" |
49 #include "chrome/browser/ui/browser_navigator.h" | 50 #include "chrome/browser/ui/browser_navigator.h" |
50 #include "chrome/browser/ui/browser_window.h" | 51 #include "chrome/browser/ui/browser_window.h" |
51 #include "chrome/browser/ui/tab_contents/tab_contents_wrapper.h" | 52 #include "chrome/browser/ui/tab_contents/tab_contents_wrapper.h" |
52 #include "chrome/common/chrome_constants.h" | 53 #include "chrome/common/chrome_constants.h" |
(...skipping 794 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
847 // If we're starting up in "background mode" (no open browser window) then | 848 // If we're starting up in "background mode" (no open browser window) then |
848 // don't open any browser windows. | 849 // don't open any browser windows. |
849 if (process_startup && command_line_.HasSwitch(switches::kNoStartupWindow)) | 850 if (process_startup && command_line_.HasSwitch(switches::kNoStartupWindow)) |
850 return; | 851 return; |
851 | 852 |
852 if (process_startup && ProcessStartupURLs(urls_to_open)) { | 853 if (process_startup && ProcessStartupURLs(urls_to_open)) { |
853 // ProcessStartupURLs processed the urls, nothing else to do. | 854 // ProcessStartupURLs processed the urls, nothing else to do. |
854 return; | 855 return; |
855 } | 856 } |
856 | 857 |
857 if (!process_startup && | 858 if (!process_startup) { |
858 (profile_->GetSessionService() && | 859 SessionService* service = SessionServiceFactory::GetForProfile(profile_); |
859 profile_->GetSessionService()->RestoreIfNecessary(urls_to_open))) { | 860 if (service && service->RestoreIfNecessary(urls_to_open)) { |
860 // We're already running and session restore wanted to run. This can happen | 861 // We're already running and session restore wanted to run. This can |
861 // at various points, such as if there is only an app window running and the | 862 // happen at various points, such as if there is only an app window |
862 // user double clicked the chrome icon. Return so we don't open the urls. | 863 // running and the user double clicked the chrome icon. Return so we don't |
863 return; | 864 // open the urls. |
| 865 return; |
| 866 } |
864 } | 867 } |
865 | 868 |
866 // Session restore didn't occur, open the urls. | 869 // Session restore didn't occur, open the urls. |
867 | 870 |
868 Browser* browser = NULL; | 871 Browser* browser = NULL; |
869 std::vector<GURL> adjust_urls = urls_to_open; | 872 std::vector<GURL> adjust_urls = urls_to_open; |
870 if (adjust_urls.empty()) | 873 if (adjust_urls.empty()) |
871 AddStartupURLs(&adjust_urls); | 874 AddStartupURLs(&adjust_urls); |
872 else if (!command_line_.HasSwitch(switches::kOpenInNewWindow)) | 875 else if (!command_line_.HasSwitch(switches::kOpenInNewWindow)) |
873 browser = BrowserList::GetLastActiveWithProfile(profile_); | 876 browser = BrowserList::GetLastActiveWithProfile(profile_); |
(...skipping 514 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1388 return false; | 1391 return false; |
1389 automation->SetExpectedTabCount(expected_tabs); | 1392 automation->SetExpectedTabCount(expected_tabs); |
1390 | 1393 |
1391 AutomationProviderList* list = | 1394 AutomationProviderList* list = |
1392 g_browser_process->InitAutomationProviderList(); | 1395 g_browser_process->InitAutomationProviderList(); |
1393 DCHECK(list); | 1396 DCHECK(list); |
1394 list->AddProvider(automation); | 1397 list->AddProvider(automation); |
1395 | 1398 |
1396 return true; | 1399 return true; |
1397 } | 1400 } |
OLD | NEW |