Chromium Code Reviews| Index: ios/chrome/browser/component_updater/component_updater_configurator.cc |
| diff --git a/ios/chrome/browser/component_updater/component_updater_configurator.cc b/ios/chrome/browser/component_updater/component_updater_configurator.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..f9e4e238a45747034c739ff2925fd16a96e1cfac |
| --- /dev/null |
| +++ b/ios/chrome/browser/component_updater/component_updater_configurator.cc |
| @@ -0,0 +1,81 @@ |
| +// Copyright 2015 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "ios/chrome/browser/component_updater/component_updater_configurator.h" |
| + |
| +#include <string> |
| + |
| +#include "base/threading/sequenced_worker_pool.h" |
| +#include "components/component_updater/default_configurator.h" |
| +#include "components/update_client/component_patcher_operation.h" |
| +#include "components/update_client/update_query_params_delegate.h" |
| +#include "ios/chrome/browser/application_context.h" |
| +#include "ios/chrome/common/channel_info.h" |
| +#include "ios/web/public/web_thread.h" |
| + |
| +namespace component_updater { |
| + |
| +namespace { |
| + |
| +class ChromeConfigurator : public DefaultConfigurator { |
| + public: |
| + ChromeConfigurator(const base::CommandLine* cmdline, |
| + net::URLRequestContextGetter* url_request_getter); |
| + |
| + std::string GetChannel() const override; |
| + std::string GetLang() const override; |
| + scoped_refptr<update_client::OutOfProcessPatcher> CreateOutOfProcessPatcher() |
| + const override; |
| + scoped_refptr<base::SequencedTaskRunner> GetSequencedTaskRunner() |
| + const override; |
| + scoped_refptr<base::SingleThreadTaskRunner> GetSingleThreadTaskRunner() |
| + const override; |
| + |
| + private: |
| + friend class base::RefCountedThreadSafe<ChromeConfigurator>; |
| + |
| + ~ChromeConfigurator() override {} |
| +}; |
| + |
| +ChromeConfigurator::ChromeConfigurator( |
| + const base::CommandLine* cmdline, |
| + net::URLRequestContextGetter* url_request_getter) |
| + : DefaultConfigurator(cmdline, url_request_getter) {} |
| + |
| +std::string ChromeConfigurator::GetChannel() const { |
| + return update_client::UpdateQueryParamsDelegate::GetChannelStringHelper( |
| + ::GetChannel()); |
| +} |
| + |
| +std::string ChromeConfigurator::GetLang() const { |
| + return GetApplicationContext()->GetApplicationLocale(); |
| +} |
| + |
| +scoped_refptr<update_client::OutOfProcessPatcher> |
| +ChromeConfigurator::CreateOutOfProcessPatcher() const { |
| + return nullptr; |
|
droger
2015/08/07 14:49:44
Is it fine to return null here? On iOS we can't do
Sorin Jianu
2015/08/12 02:27:51
It is correct to return nullptr in this case, acco
|
| +} |
| + |
| +scoped_refptr<base::SequencedTaskRunner> |
| +ChromeConfigurator::GetSequencedTaskRunner() const { |
| + return web::WebThread::GetBlockingPool() |
| + ->GetSequencedTaskRunnerWithShutdownBehavior( |
| + web::WebThread::GetBlockingPool()->GetSequenceToken(), |
| + base::SequencedWorkerPool::SKIP_ON_SHUTDOWN); |
| +} |
| + |
| +scoped_refptr<base::SingleThreadTaskRunner> |
| +ChromeConfigurator::GetSingleThreadTaskRunner() const { |
| + return web::WebThread::GetTaskRunnerForThread(web::WebThread::FILE); |
| +} |
| + |
| +} // namespace |
| + |
| +scoped_refptr<update_client::Configurator> MakeComponentUpdaterConfigurator( |
| + const base::CommandLine* cmdline, |
| + net::URLRequestContextGetter* context_getter) { |
| + return new ChromeConfigurator(cmdline, context_getter); |
| +} |
| + |
| +} // namespace component_updater |