OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef CHROME_BROWSER_EXTENSIONS_EXTENSION_SYSTEM_FACTORY_H_ | 5 #ifndef CHROME_BROWSER_EXTENSIONS_EXTENSION_SYSTEM_FACTORY_H_ |
6 #define CHROME_BROWSER_EXTENSIONS_EXTENSION_SYSTEM_FACTORY_H_ | 6 #define CHROME_BROWSER_EXTENSIONS_EXTENSION_SYSTEM_FACTORY_H_ |
7 | 7 |
8 #include "base/memory/singleton.h" | 8 #include "base/memory/singleton.h" |
9 #include "chrome/browser/extensions/extension_system.h" | 9 #include "chrome/browser/extensions/extension_system.h" |
10 #include "components/browser_context_keyed_service/browser_context_keyed_service
_factory.h" | 10 #include "components/browser_context_keyed_service/browser_context_keyed_service
_factory.h" |
11 | 11 |
| 12 class BrowserContextKeyedService; |
12 class Profile; | 13 class Profile; |
13 class ProfileKeyedService; | |
14 | 14 |
15 namespace extensions { | 15 namespace extensions { |
16 class ExtensionSystem; | 16 class ExtensionSystem; |
17 | 17 |
18 // ProfileKeyedServiceFactory for ExtensionSystemImpl::Shared. | 18 // BrowserContextKeyedServiceFactory for ExtensionSystemImpl::Shared. |
19 // Should not be used except by ExtensionSystem(Factory). | 19 // Should not be used except by ExtensionSystem(Factory). |
20 class ExtensionSystemSharedFactory : public ProfileKeyedServiceFactory { | 20 class ExtensionSystemSharedFactory : public BrowserContextKeyedServiceFactory { |
21 public: | 21 public: |
22 static ExtensionSystemImpl::Shared* GetForProfile( | 22 static ExtensionSystemImpl::Shared* GetForProfile( |
23 Profile* profile); | 23 Profile* profile); |
24 | 24 |
25 static ExtensionSystemSharedFactory* GetInstance(); | 25 static ExtensionSystemSharedFactory* GetInstance(); |
26 | 26 |
27 private: | 27 private: |
28 friend struct DefaultSingletonTraits<ExtensionSystemSharedFactory>; | 28 friend struct DefaultSingletonTraits<ExtensionSystemSharedFactory>; |
29 | 29 |
30 ExtensionSystemSharedFactory(); | 30 ExtensionSystemSharedFactory(); |
31 virtual ~ExtensionSystemSharedFactory(); | 31 virtual ~ExtensionSystemSharedFactory(); |
32 | 32 |
33 virtual ProfileKeyedService* BuildServiceInstanceFor( | 33 virtual BrowserContextKeyedService* BuildServiceInstanceFor( |
34 content::BrowserContext* profile) const OVERRIDE; | 34 content::BrowserContext* profile) const OVERRIDE; |
35 virtual content::BrowserContext* GetBrowserContextToUse( | 35 virtual content::BrowserContext* GetBrowserContextToUse( |
36 content::BrowserContext* context) const OVERRIDE; | 36 content::BrowserContext* context) const OVERRIDE; |
37 }; | 37 }; |
38 | 38 |
39 // ProfileKeyedServiceFactory for ExtensionSystem. | 39 // BrowserContextKeyedServiceFactory for ExtensionSystem. |
40 class ExtensionSystemFactory : public ProfileKeyedServiceFactory { | 40 class ExtensionSystemFactory : public BrowserContextKeyedServiceFactory { |
41 public: | 41 public: |
42 // ProfileKeyedServiceFactory implementation: | 42 // BrowserContextKeyedServiceFactory implementation: |
43 static ExtensionSystem* GetForProfile(Profile* profile); | 43 static ExtensionSystem* GetForProfile(Profile* profile); |
44 | 44 |
45 static ExtensionSystemFactory* GetInstance(); | 45 static ExtensionSystemFactory* GetInstance(); |
46 | 46 |
47 private: | 47 private: |
48 friend struct DefaultSingletonTraits<ExtensionSystemFactory>; | 48 friend struct DefaultSingletonTraits<ExtensionSystemFactory>; |
49 | 49 |
50 ExtensionSystemFactory(); | 50 ExtensionSystemFactory(); |
51 virtual ~ExtensionSystemFactory(); | 51 virtual ~ExtensionSystemFactory(); |
52 | 52 |
53 virtual ProfileKeyedService* BuildServiceInstanceFor( | 53 virtual BrowserContextKeyedService* BuildServiceInstanceFor( |
54 content::BrowserContext* profile) const OVERRIDE; | 54 content::BrowserContext* profile) const OVERRIDE; |
55 virtual content::BrowserContext* GetBrowserContextToUse( | 55 virtual content::BrowserContext* GetBrowserContextToUse( |
56 content::BrowserContext* context) const OVERRIDE; | 56 content::BrowserContext* context) const OVERRIDE; |
57 virtual bool ServiceIsCreatedWithProfile() const OVERRIDE; | 57 virtual bool ServiceIsCreatedWithBrowserContext() const OVERRIDE; |
58 }; | 58 }; |
59 | 59 |
60 } // namespace extensions | 60 } // namespace extensions |
61 | 61 |
62 #endif // CHROME_BROWSER_EXTENSIONS_EXTENSION_SYSTEM_FACTORY_H_ | 62 #endif // CHROME_BROWSER_EXTENSIONS_EXTENSION_SYSTEM_FACTORY_H_ |
OLD | NEW |