OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 #include "chrome/browser/media/router/media_router_factory.h" | 5 #include "chrome/browser/media/router/media_router_factory.h" |
6 | 6 |
7 #include "build/build_config.h" | 7 #include "build/build_config.h" |
8 #include "chrome/browser/profiles/incognito_helpers.h" | 8 #include "chrome/browser/profiles/incognito_helpers.h" |
9 #include "chrome/browser/profiles/profile.h" | 9 #include "chrome/browser/profiles/profile.h" |
10 #include "components/keyed_service/content/browser_context_dependency_manager.h" | 10 #include "components/keyed_service/content/browser_context_dependency_manager.h" |
11 | 11 |
12 #if defined(OS_ANDROID) | 12 #if defined(OS_ANDROID) |
13 #include "chrome/browser/media/android/router/media_router_android.h" | 13 #include "chrome/browser/media/android/router/media_router_android.h" |
14 #else | 14 #else |
15 #include "chrome/browser/media/router/mojo/media_router_mojo_impl.h" | 15 #include "chrome/browser/media/router/mojo/media_router_mojo_impl.h" |
| 16 #include "chrome/browser/ui/toolbar/toolbar_actions_model_factory.h" |
16 #include "extensions/browser/process_manager.h" | 17 #include "extensions/browser/process_manager.h" |
17 #include "extensions/browser/process_manager_factory.h" | 18 #include "extensions/browser/process_manager_factory.h" |
18 #endif | 19 #endif |
19 | 20 |
20 using content::BrowserContext; | 21 using content::BrowserContext; |
21 | 22 |
22 namespace media_router { | 23 namespace media_router { |
23 | 24 |
24 namespace { | 25 namespace { |
25 | 26 |
(...skipping 23 matching lines...) Expand all Loading... |
49 BrowserContextKeyedServiceFactory::BrowserContextShutdown(context); | 50 BrowserContextKeyedServiceFactory::BrowserContextShutdown(context); |
50 } | 51 } |
51 | 52 |
52 MediaRouterFactory::MediaRouterFactory() | 53 MediaRouterFactory::MediaRouterFactory() |
53 : BrowserContextKeyedServiceFactory( | 54 : BrowserContextKeyedServiceFactory( |
54 "MediaRouter", | 55 "MediaRouter", |
55 BrowserContextDependencyManager::GetInstance()) { | 56 BrowserContextDependencyManager::GetInstance()) { |
56 #if !defined(OS_ANDROID) | 57 #if !defined(OS_ANDROID) |
57 // On desktop platforms, MediaRouter depends on ProcessManager. | 58 // On desktop platforms, MediaRouter depends on ProcessManager. |
58 DependsOn(extensions::ProcessManagerFactory::GetInstance()); | 59 DependsOn(extensions::ProcessManagerFactory::GetInstance()); |
| 60 // On desktop platforms, MediaRouter owns a MediaRouterActionController |
| 61 // that depends on ToolbarActionsModel. |
| 62 DependsOn(ToolbarActionsModelFactory::GetInstance()); |
59 #endif | 63 #endif |
60 } | 64 } |
61 | 65 |
62 MediaRouterFactory::~MediaRouterFactory() { | 66 MediaRouterFactory::~MediaRouterFactory() { |
63 } | 67 } |
64 | 68 |
65 // static | 69 // static |
66 MediaRouterFactory* MediaRouterFactory::GetMediaRouterFactoryForTest() { | 70 MediaRouterFactory* MediaRouterFactory::GetMediaRouterFactoryForTest() { |
67 return &service_factory.Get(); | 71 return &service_factory.Get(); |
68 } | 72 } |
69 | 73 |
70 content::BrowserContext* MediaRouterFactory::GetBrowserContextToUse( | 74 content::BrowserContext* MediaRouterFactory::GetBrowserContextToUse( |
71 content::BrowserContext* context) const { | 75 content::BrowserContext* context) const { |
72 return chrome::GetBrowserContextRedirectedInIncognito(context); | 76 return chrome::GetBrowserContextRedirectedInIncognito(context); |
73 } | 77 } |
74 | 78 |
75 KeyedService* MediaRouterFactory::BuildServiceInstanceFor( | 79 KeyedService* MediaRouterFactory::BuildServiceInstanceFor( |
76 BrowserContext* context) const { | 80 BrowserContext* context) const { |
77 MediaRouterBase* media_router = nullptr; | 81 MediaRouterBase* media_router = nullptr; |
78 #if defined(OS_ANDROID) | 82 #if defined(OS_ANDROID) |
79 media_router = new MediaRouterAndroid(context); | 83 media_router = new MediaRouterAndroid(context); |
80 #else | 84 #else |
81 media_router = | 85 media_router = new MediaRouterMojoImpl( |
82 new MediaRouterMojoImpl(extensions::ProcessManager::Get(context)); | 86 context, extensions::ProcessManager::Get(context)); |
83 #endif | 87 #endif |
84 media_router->Initialize(); | 88 media_router->Initialize(); |
85 return media_router; | 89 return media_router; |
86 } | 90 } |
87 | 91 |
88 } // namespace media_router | 92 } // namespace media_router |
OLD | NEW |