Chromium Code Reviews| Index: ios/chrome/browser/translate/language_model_factory.cc |
| diff --git a/ios/chrome/browser/translate/language_model_factory.cc b/ios/chrome/browser/translate/language_model_factory.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..c6505c7da9196628e4d09d38b62360444ff65efd |
| --- /dev/null |
| +++ b/ios/chrome/browser/translate/language_model_factory.cc |
| @@ -0,0 +1,40 @@ |
| +// Copyright 2017 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/translate/language_model_factory.h" |
| + |
| +#include "base/memory/ptr_util.h" |
| +#include "components/keyed_service/core/keyed_service.h" |
| +#include "components/keyed_service/ios/browser_state_dependency_manager.h" |
| +#include "components/translate/core/browser/language_model.h" |
| +#include "ios/chrome/browser/browser_state/chrome_browser_state.h" |
| + |
| +namespace translate { |
| + |
| +// static |
| +LanguageModelFactory* LanguageModelFactory::GetInstance() { |
| + return base::Singleton<LanguageModelFactory>::get(); |
| +} |
| + |
| +// static |
| +translate::LanguageModel* LanguageModelFactory::GetForBrowserState( |
| + ios::ChromeBrowserState* state) { |
|
martis
2017/06/01 06:49:21
In general, I think we should try to be as const-c
ramyasharma
2017/06/02 07:20:24
Thanks Michael. I have changed it in here. I am no
|
| + return static_cast<LanguageModel*>( |
| + GetInstance()->GetServiceForBrowserState(state, true)); |
| +} |
| + |
| +LanguageModelFactory::LanguageModelFactory() |
| + : BrowserStateKeyedServiceFactory( |
| + "LanguageModel", |
| + BrowserStateDependencyManager::GetInstance()) {} |
| + |
| +LanguageModelFactory::~LanguageModelFactory() {} |
| + |
| +std::unique_ptr<KeyedService> LanguageModelFactory::BuildServiceInstanceFor( |
| + web::BrowserState* context) const { |
| + ios::ChromeBrowserState* browser_state = |
| + ios::ChromeBrowserState::FromBrowserState(context); |
| + return base::MakeUnique<translate::LanguageModel>(browser_state->GetPrefs()); |
| +} |
| +} |