Chromium Code Reviews| Index: components/ntp_snippets/ntp_snippets_service.cc |
| diff --git a/components/ntp_snippets/ntp_snippets_service.cc b/components/ntp_snippets/ntp_snippets_service.cc |
| index 66a923fe1e367cdc84df1e3f5a7338e637c392e3..db962648a7ac5bd1522e97dbd0ec5aa1da7bfa0d 100644 |
| --- a/components/ntp_snippets/ntp_snippets_service.cc |
| +++ b/components/ntp_snippets/ntp_snippets_service.cc |
| @@ -14,6 +14,12 @@ |
| namespace ntp_snippets { |
|
noyau (Ping after 24h)
2016/02/22 11:58:49
nit: I would avoid nesting the namespaces, this li
Marc Treib
2016/02/22 12:44:32
Done.
Nesting is a somewhat common pattern though.
|
| +namespace { |
| + |
| +// TODO(treib): This is an extremely small value, for ease of development. |
|
noyau (Ping after 24h)
2016/02/22 11:58:49
Please use the format TODO(crbug/XXXX): and add a
Bernhard Bauer
2016/02/22 12:05:12
Nit: `TODO(crbug.com/1234)`, to make it clickable
Marc Treib
2016/02/22 12:44:31
Done.
|
| +// Replace it by something sensible and add a command line param to control it. |
| +const int kDefaultFetchingIntervalSeconds = 60; |
| + |
| std::string ReadFileToString(const base::FilePath& path) { |
| std::string data; |
| bool success = base::ReadFileToString(path, &data); |
| @@ -22,13 +28,17 @@ std::string ReadFileToString(const base::FilePath& path) { |
| return data; |
| } |
| +} // namespace |
| + |
| NTPSnippetsService::NTPSnippetsService( |
| scoped_refptr<base::SequencedTaskRunner> file_task_runner, |
| const std::string& application_language_code, |
| + NTPSnippetsScheduler* scheduler, |
| scoped_ptr<NTPSnippetsFetcher> snippets_fetcher) |
| : loaded_(false), |
| file_task_runner_(file_task_runner), |
| application_language_code_(application_language_code), |
| + scheduler_(scheduler), |
| snippets_fetcher_(std::move(snippets_fetcher)), |
| weak_ptr_factory_(this) { |
| snippets_fetcher_callback_ = snippets_fetcher_->AddCallback( |
| @@ -38,6 +48,17 @@ NTPSnippetsService::NTPSnippetsService( |
| NTPSnippetsService::~NTPSnippetsService() {} |
| +void NTPSnippetsService::Init(bool enabled) { |
| + // The scheduler only exists on Android so far, it's null on other platforms. |
| + if (!scheduler_) |
| + return; |
| + |
| + if (enabled) |
| + scheduler_->Schedule(kDefaultFetchingIntervalSeconds); |
| + else |
| + scheduler_->Unschedule(); |
| +} |
| + |
| void NTPSnippetsService::Shutdown() { |
| FOR_EACH_OBSERVER(NTPSnippetsServiceObserver, observers_, |
| NTPSnippetsServiceShutdown(this)); |