OLD | NEW |
---|---|
(Empty) | |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 #include "components/translate/content/browser/browser_cld_data_provider_factory .h" | |
6 | |
7 #include "base/lazy_instance.h" | |
8 #include "components/translate/content/browser/browser_cld_data_provider.h" | |
9 | |
10 namespace { | |
11 translate::BrowserCldDataProviderFactory* g_instance = NULL; | |
12 | |
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.
| |
13 // The default factory | |
14 struct WrappedDefault { | |
15 WrappedDefault() { | |
16 value = new translate::BrowserCldDataProviderFactory(); | |
17 } | |
18 translate::BrowserCldDataProviderFactory* value; | |
19 }; | |
20 base::LazyInstance<WrappedDefault>::Leaky g_wrapped_default = | |
21 LAZY_INSTANCE_INITIALIZER; | |
22 | |
23 } // namespace | |
24 | |
25 | |
26 namespace translate { | |
27 | |
28 BrowserCldDataProviderFactory::BrowserCldDataProviderFactory() { | |
29 } | |
30 | |
31 BrowserCldDataProviderFactory::~BrowserCldDataProviderFactory() { | |
32 } | |
33 | |
34 BrowserCldDataProvider* BrowserCldDataProviderFactory::NewProvider( | |
35 content::WebContents* web_contents) { | |
36 return new BrowserCldDataProvider(); | |
37 } | |
38 | |
39 bool BrowserCldDataProviderFactory::IsInitialized() { | |
40 return g_instance != NULL; | |
41 } | |
42 | |
43 void BrowserCldDataProviderFactory::Set( | |
44 BrowserCldDataProviderFactory* instance, bool overwrite) { | |
45 if (overwrite || g_instance == NULL) { | |
46 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
| |
47 } | |
48 } | |
49 | |
50 BrowserCldDataProviderFactory* BrowserCldDataProviderFactory::Get() { | |
51 if (g_instance == NULL) { | |
52 // No provider set. OK for test code and narrow use cases, but bad if it is | |
53 // a real browser. Since there's no good way to differentiate these use | |
54 // cases at runtime, don't log a warning here. | |
55 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.
| |
56 } | |
57 return g_instance; | |
58 } | |
59 | |
60 } // namespace translate | |
OLD | NEW |