Chromium Code Reviews| Index: chrome/browser/ui/startup/startup_tab_provider.cc |
| diff --git a/chrome/browser/ui/startup/startup_tab_provider.cc b/chrome/browser/ui/startup/startup_tab_provider.cc |
| index 1f4bbfd1f0b2d44e6b6403b0251f0386d2a33156..635e3ef11bb01cf5984f84e7a590035f87d67311 100644 |
| --- a/chrome/browser/ui/startup/startup_tab_provider.cc |
| +++ b/chrome/browser/ui/startup/startup_tab_provider.cc |
| @@ -9,6 +9,7 @@ |
| #include "chrome/browser/profile_resetter/triggered_profile_resetter.h" |
| #include "chrome/browser/profile_resetter/triggered_profile_resetter_factory.h" |
| #include "chrome/browser/ui/chrome_pages.h" |
| +#include "chrome/browser/ui/tabs/pinned_tab_codec.h" |
| #include "chrome/common/url_constants.h" |
| #include "chrome/grit/locale_settings.h" |
| #include "ui/base/l10n/l10n_util.h" |
| @@ -52,16 +53,15 @@ StartupTabs StartupTabProviderImpl::GetResetTriggerTabs( |
| return CheckResetTriggerTabPolicy(has_reset_trigger); |
| } |
| -StartupTabs StartupTabProviderImpl::GetPinnedTabs() const { |
| - // TODO(tmartino): Copy/clean up logic from |
| - // StartupBrowserCreatorImpl::ProcessSpecifiedUrls. |
| - return StartupTabs(); |
| +StartupTabs StartupTabProviderImpl::GetPinnedTabs(Profile* profile) const { |
| + return PinnedTabCodec::ReadPinnedTabs(profile); |
| } |
| -StartupTabs StartupTabProviderImpl::GetPreferencesTabs() const { |
| - // TODO(tmartino): Copy/clean up logic from |
| - // StartupBrowserCreatorImpl::ProcessStartupUrls. |
| - return StartupTabs(); |
| +StartupTabs StartupTabProviderImpl::GetPreferencesTabs( |
| + const base::CommandLine& command_line, |
| + Profile* profile) const { |
| + return CheckPreferencesTabPolicy( |
| + StartupBrowserCreator::GetSessionStartupPref(command_line, profile)); |
| } |
| // static |
| @@ -79,8 +79,8 @@ StartupTabs StartupTabProviderImpl::CheckMasterPrefsTabPolicy( |
| const std::vector<GURL>& first_run_tabs) { |
| // Constants: Magic words used by Master Preferences files in place of a URL |
| // host to indicate that internal pages should appear on first run. |
| - constexpr char kNewTabUrlHost[] = "new_tab_page"; |
| - constexpr char kWelcomePageUrlHost[] = "welcome_page"; |
| + static constexpr char kNewTabUrlHost[] = "new_tab_page"; |
| + static constexpr char kWelcomePageUrlHost[] = "welcome_page"; |
| StartupTabs tabs; |
| if (is_first_run) { |
| @@ -106,6 +106,17 @@ StartupTabs StartupTabProviderImpl::CheckResetTriggerTabPolicy( |
| } |
| // static |
| +StartupTabs StartupTabProviderImpl::CheckPreferencesTabPolicy( |
| + SessionStartupPref pref) { |
|
grt (UTC plus 2)
2016/10/24 06:55:35
should this be passed by const-ref since it contai
|
| + StartupTabs tabs; |
| + if (pref.type == SessionStartupPref::Type::URLS && !pref.urls.empty()) { |
| + for (auto& url : pref.urls) |
|
grt (UTC plus 2)
2016/10/24 06:55:35
nit: "const auto&"
|
| + tabs.push_back(StartupTab(url, false)); |
| + } |
| + return tabs; |
| +} |
| + |
| +// static |
| GURL StartupTabProviderImpl::GetWelcomePageUrl() { |
| return GURL(chrome::kChromeUIWelcomeURL); |
| } |