Chromium Code Reviews| Index: components/translate/content/browser/browser_cld_data_provider_factory.cc |
| diff --git a/components/translate/content/browser/browser_cld_data_provider_factory.cc b/components/translate/content/browser/browser_cld_data_provider_factory.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..75ff7bd4726d53ddf2554277fd6bb7a1aa62cd94 |
| --- /dev/null |
| +++ b/components/translate/content/browser/browser_cld_data_provider_factory.cc |
| @@ -0,0 +1,60 @@ |
| +// Copyright 2014 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 "components/translate/content/browser/browser_cld_data_provider_factory.h" |
| + |
| +#include "base/lazy_instance.h" |
| +#include "components/translate/content/browser/browser_cld_data_provider.h" |
| + |
| +namespace { |
| +translate::BrowserCldDataProviderFactory* g_instance = NULL; |
| + |
|
picksi1
2014/09/29 15:59:08
This looks familiar! Is there a common pattern her
Andrew Hayden (chromium.org)
2014/10/30 14:25:15
Similarly, this is now cleaned up.
|
| +// The default factory |
| +struct WrappedDefault { |
| + WrappedDefault() { |
| + value = new translate::BrowserCldDataProviderFactory(); |
| + } |
| + translate::BrowserCldDataProviderFactory* value; |
| +}; |
| +base::LazyInstance<WrappedDefault>::Leaky g_wrapped_default = |
| + LAZY_INSTANCE_INITIALIZER; |
| + |
| +} // namespace |
| + |
| + |
| +namespace translate { |
| + |
| +BrowserCldDataProviderFactory::BrowserCldDataProviderFactory() { |
| +} |
| + |
| +BrowserCldDataProviderFactory::~BrowserCldDataProviderFactory() { |
| +} |
| + |
| +BrowserCldDataProvider* BrowserCldDataProviderFactory::NewProvider( |
| + content::WebContents* web_contents) { |
| + return new BrowserCldDataProvider(); |
| +} |
| + |
| +bool BrowserCldDataProviderFactory::IsInitialized() { |
| + return g_instance != NULL; |
| +} |
| + |
| +void BrowserCldDataProviderFactory::Set( |
| + BrowserCldDataProviderFactory* instance, bool overwrite) { |
| + if (overwrite || g_instance == NULL) { |
| + g_instance = instance; |
|
picksi1
2014/09/29 15:59:08
Now I understand what the bool does! It might be b
Andrew Hayden (chromium.org)
2014/10/30 14:25:15
Done
|
| + } |
| +} |
| + |
| +BrowserCldDataProviderFactory* BrowserCldDataProviderFactory::Get() { |
| + if (g_instance == NULL) { |
| + // No provider set. OK for test code and narrow use cases, but bad if it is |
| + // a real browser. Since there's no good way to differentiate these use |
| + // cases at runtime, don't log a warning here. |
| + return g_wrapped_default.Get().value; |
|
picksi1
2014/09/29 15:59:08
Can we lazily initialize (to a default?) in here?
Andrew Hayden (chromium.org)
2014/10/30 14:25:15
That's what we're doing. Cleaner now.
|
| + } |
| + return g_instance; |
| +} |
| + |
| +} // namespace translate |