Chromium Code Reviews| 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 #ifndef CHROME_BROWSER_UI_STARTUP_STARTUP_BROWSER_CREATOR_IMPL_H_ | 5 #ifndef CHROME_BROWSER_UI_STARTUP_STARTUP_BROWSER_CREATOR_IMPL_H_ |
| 6 #define CHROME_BROWSER_UI_STARTUP_STARTUP_BROWSER_CREATOR_IMPL_H_ | 6 #define CHROME_BROWSER_UI_STARTUP_STARTUP_BROWSER_CREATOR_IMPL_H_ |
| 7 | 7 |
| 8 #include <string> | 8 #include <string> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| 11 #include "base/files/file_path.h" | 11 #include "base/files/file_path.h" |
| 12 #include "base/gtest_prod_util.h" | 12 #include "base/gtest_prod_util.h" |
| 13 #include "base/macros.h" | 13 #include "base/macros.h" |
| 14 #include "chrome/browser/ui/startup/startup_tab.h" | 14 #include "chrome/browser/ui/startup/startup_tab.h" |
| 15 #include "chrome/browser/ui/startup/startup_tab_provider.h" | |
| 15 #include "chrome/browser/ui/startup/startup_types.h" | 16 #include "chrome/browser/ui/startup/startup_types.h" |
| 16 #include "url/gurl.h" | 17 #include "url/gurl.h" |
| 17 | 18 |
| 18 class Browser; | 19 class Browser; |
| 19 class Profile; | 20 class Profile; |
| 20 class StartupBrowserCreator; | 21 class StartupBrowserCreator; |
| 21 | 22 |
| 22 namespace base { | 23 namespace base { |
| 23 class CommandLine; | 24 class CommandLine; |
| 24 class FilePath; | 25 class FilePath; |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 60 | 61 |
| 61 // Convenience for OpenTabsInBrowser that converts |urls| into a set of | 62 // Convenience for OpenTabsInBrowser that converts |urls| into a set of |
| 62 // Tabs. | 63 // Tabs. |
| 63 Browser* OpenURLsInBrowser(Browser* browser, | 64 Browser* OpenURLsInBrowser(Browser* browser, |
| 64 bool process_startup, | 65 bool process_startup, |
| 65 const std::vector<GURL>& urls); | 66 const std::vector<GURL>& urls); |
| 66 | 67 |
| 67 private: | 68 private: |
| 68 FRIEND_TEST_ALL_PREFIXES(BrowserTest, RestorePinnedTabs); | 69 FRIEND_TEST_ALL_PREFIXES(BrowserTest, RestorePinnedTabs); |
| 69 FRIEND_TEST_ALL_PREFIXES(BrowserTest, AppIdSwitch); | 70 FRIEND_TEST_ALL_PREFIXES(BrowserTest, AppIdSwitch); |
| 71 FRIEND_TEST_ALL_PREFIXES(StartupBrowserCreatorImplTest, DetermineStartupTabs); | |
| 72 FRIEND_TEST_ALL_PREFIXES(StartupBrowserCreatorImplTest, | |
| 73 DetermineStartupTabs_IncognitoOrCrash); | |
| 74 FRIEND_TEST_ALL_PREFIXES(StartupBrowserCreatorImplTest, | |
| 75 DetermineStartupTabs_MasterPrefs); | |
| 70 | 76 |
| 71 enum class WelcomeRunType { | 77 enum class WelcomeRunType { |
| 72 NONE, // Do not inject the welcome page for this run. | 78 NONE, // Do not inject the welcome page for this run. |
| 73 FIRST_TAB, // Inject the welcome page as the first tab. | 79 FIRST_TAB, // Inject the welcome page as the first tab. |
| 74 FIRST_RUN_LAST_TAB, // Inject the welcome page as the last first-run tab. | 80 FIRST_RUN_LAST_TAB, // Inject the welcome page as the last first-run tab. |
| 75 }; | 81 }; |
| 76 | 82 |
| 77 // Creates a tab for each of the Tabs in |tabs|. If browser is non-null | 83 // Creates a tab for each of the Tabs in |tabs|. If browser is non-null |
| 78 // and a tabbed browser, the tabs are added to it. Otherwise a new tabbed | 84 // and a tabbed browser, the tabs are added to it. Otherwise a new tabbed |
| 79 // browser is created and the tabs are added to it. The browser the tabs | 85 // browser is created and the tabs are added to it. The browser the tabs |
| (...skipping 19 matching lines...) Expand all Loading... | |
| 99 | 105 |
| 100 // Invoked from Launch to handle processing of urls. This may do any of the | 106 // Invoked from Launch to handle processing of urls. This may do any of the |
| 101 // following: | 107 // following: |
| 102 // . Invoke ProcessStartupURLs if |process_startup| is true. | 108 // . Invoke ProcessStartupURLs if |process_startup| is true. |
| 103 // . If |process_startup| is false, restore the last session if necessary, | 109 // . If |process_startup| is false, restore the last session if necessary, |
| 104 // or invoke ProcessSpecifiedURLs. | 110 // or invoke ProcessSpecifiedURLs. |
| 105 // . Open the urls directly. | 111 // . Open the urls directly. |
| 106 void ProcessLaunchURLs(bool process_startup, | 112 void ProcessLaunchURLs(bool process_startup, |
| 107 const std::vector<GURL>& urls_to_open); | 113 const std::vector<GURL>& urls_to_open); |
| 108 | 114 |
| 115 // Determines the URLs to be shown at startup by way of various policies | |
| 116 // (onboarding, pinned tabs, etc.), determines whether a session restore | |
| 117 // is necessary, and opens the content a new or restored browser accordingly. | |
|
grt (UTC plus 2)
2016/09/09 11:40:30
"opens the content"?
| |
| 118 // This method is a refactoring of ProcessLaunchURLs above, and will replace | |
| 119 // that code path entirely once kUseConsolidatedStartupFlow is on by default. | |
| 120 void ProcessLaunchUrlsUsingConsolidatedFlow( | |
| 121 bool process_startup, | |
| 122 const std::vector<GURL>& urls_to_open); | |
| 123 | |
| 124 // Returns the tabs to be shown on startup, based on the policy functions | |
|
grt (UTC plus 2)
2016/09/09 11:40:30
...on startup when no URLs are provided on the com
| |
| 125 // in the given StartupTabProvider, and the interactions between those | |
| 126 // policies. | |
| 127 StartupTabs DetermineStartupTabs(StartupTabProvider* provider, | |
| 128 bool is_incognito, | |
| 129 bool is_crash); | |
| 130 | |
| 131 // Opens the given tabs in a new browser. | |
| 132 // TODO(tmartino): Add the ability to restore a session, and an additional | |
| 133 // argument which indicates which behavior (new or restored) should be used. | |
| 134 Browser* RestoreOrCreateBrowser(StartupTabs tabs); | |
| 135 | |
| 109 // Does the following: | 136 // Does the following: |
| 110 // . If the user's startup pref is to restore the last session (or the | 137 // . If the user's startup pref is to restore the last session (or the |
| 111 // command line flag is present to force using last session), it is | 138 // command line flag is present to force using last session), it is |
| 112 // restored. | 139 // restored. |
| 113 // . Otherwise invoke ProcessSpecifiedURLs | 140 // . Otherwise invoke ProcessSpecifiedURLs |
| 114 // If a browser was created, true is returned. Otherwise returns false and | 141 // If a browser was created, true is returned. Otherwise returns false and |
| 115 // the caller must create a new browser. | 142 // the caller must create a new browser. |
| 116 bool ProcessStartupURLs(const std::vector<GURL>& urls_to_open); | 143 bool ProcessStartupURLs(const std::vector<GURL>& urls_to_open); |
| 117 | 144 |
| 118 // Invoked from either ProcessLaunchURLs or ProcessStartupURLs to handle | 145 // Invoked from either ProcessLaunchURLs or ProcessStartupURLs to handle |
| (...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 158 const base::FilePath cur_dir_; | 185 const base::FilePath cur_dir_; |
| 159 const base::CommandLine& command_line_; | 186 const base::CommandLine& command_line_; |
| 160 Profile* profile_; | 187 Profile* profile_; |
| 161 StartupBrowserCreator* browser_creator_; | 188 StartupBrowserCreator* browser_creator_; |
| 162 bool is_first_run_; | 189 bool is_first_run_; |
| 163 WelcomeRunType welcome_run_type_; | 190 WelcomeRunType welcome_run_type_; |
| 164 DISALLOW_COPY_AND_ASSIGN(StartupBrowserCreatorImpl); | 191 DISALLOW_COPY_AND_ASSIGN(StartupBrowserCreatorImpl); |
| 165 }; | 192 }; |
| 166 | 193 |
| 167 #endif // CHROME_BROWSER_UI_STARTUP_STARTUP_BROWSER_CREATOR_IMPL_H_ | 194 #endif // CHROME_BROWSER_UI_STARTUP_STARTUP_BROWSER_CREATOR_IMPL_H_ |
| OLD | NEW |