Chromium Code Reviews| 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 "components/arc/arc_service_manager.h" | 5 #include "components/arc/arc_service_manager.h" |
| 6 | 6 |
| 7 #include <utility> | |
| 8 | |
| 9 #include "base/logging.h" | 7 #include "base/logging.h" |
| 10 #include "base/memory/ptr_util.h" | 8 #include "base/memory/ptr_util.h" |
| 11 #include "base/task_runner.h" | 9 #include "base/task_runner.h" |
| 12 #include "components/arc/arc_bridge_service.h" | 10 #include "components/arc/arc_bridge_service.h" |
| 13 #include "components/arc/arc_session.h" | 11 #include "components/arc/arc_session.h" |
| 14 #include "components/arc/arc_session_runner.h" | 12 #include "components/arc/arc_session_runner.h" |
| 15 #include "components/arc/intent_helper/arc_intent_helper_observer.h" | 13 #include "components/arc/intent_helper/arc_intent_helper_observer.h" |
| 16 | 14 |
| 17 namespace arc { | 15 namespace arc { |
| 18 namespace { | 16 namespace { |
| (...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 68 return nullptr; | 66 return nullptr; |
| 69 DCHECK(g_arc_service_manager->thread_checker_.CalledOnValidThread()); | 67 DCHECK(g_arc_service_manager->thread_checker_.CalledOnValidThread()); |
| 70 return g_arc_service_manager; | 68 return g_arc_service_manager; |
| 71 } | 69 } |
| 72 | 70 |
| 73 ArcBridgeService* ArcServiceManager::arc_bridge_service() { | 71 ArcBridgeService* ArcServiceManager::arc_bridge_service() { |
| 74 DCHECK(thread_checker_.CalledOnValidThread()); | 72 DCHECK(thread_checker_.CalledOnValidThread()); |
| 75 return arc_bridge_service_.get(); | 73 return arc_bridge_service_.get(); |
| 76 } | 74 } |
| 77 | 75 |
| 78 void ArcServiceManager::AddService(std::unique_ptr<ArcService> service) { | 76 void ArcServiceManager::AddServiceInternal( |
| 77 std::unique_ptr<ArcService> service) { | |
| 79 DCHECK(thread_checker_.CalledOnValidThread()); | 78 DCHECK(thread_checker_.CalledOnValidThread()); |
| 80 services_.emplace_back(std::move(service)); | 79 services_.emplace_back(std::move(service)); |
| 81 } | 80 } |
| 82 | 81 |
| 82 void ArcServiceManager::AddNamedServiceInternal( | |
| 83 const std::string& name, | |
| 84 std::unique_ptr<ArcService> service) { | |
| 85 DCHECK(thread_checker_.CalledOnValidThread()); | |
| 86 DCHECK(named_services_.find(name) == named_services_.end()); | |
|
Yusuke Sato
2017/01/10 07:11:10
What about making this a CHECK? Otherwise, L87 wil
Luis Héctor Chávez
2017/01/10 18:41:55
CHECKs are frowned upon outside of base/. I will a
| |
| 87 named_services_.insert(std::make_pair(name, std::move(service))); | |
|
hidehiko
2017/01/10 08:03:12
emplace?
Luis Héctor Chávez
2017/01/10 18:41:55
emplace is not supported for maps: https://chromiu
hidehiko
2017/01/11 05:17:44
Oh, good to know. Thank you!
| |
| 88 } | |
| 89 | |
| 90 ArcService* ArcServiceManager::GetNamedServiceInternal( | |
| 91 const std::string& name) { | |
| 92 DCHECK(thread_checker_.CalledOnValidThread()); | |
| 93 auto service = named_services_.find(name); | |
| 94 DCHECK(service != named_services_.end()); | |
| 95 return service->second.get(); | |
| 96 } | |
| 97 | |
| 83 void ArcServiceManager::AddObserver(Observer* observer) { | 98 void ArcServiceManager::AddObserver(Observer* observer) { |
| 84 DCHECK(thread_checker_.CalledOnValidThread()); | 99 DCHECK(thread_checker_.CalledOnValidThread()); |
| 85 observer_list_.AddObserver(observer); | 100 observer_list_.AddObserver(observer); |
| 86 } | 101 } |
| 87 | 102 |
| 88 void ArcServiceManager::RemoveObserver(Observer* observer) { | 103 void ArcServiceManager::RemoveObserver(Observer* observer) { |
| 89 DCHECK(thread_checker_.CalledOnValidThread()); | 104 DCHECK(thread_checker_.CalledOnValidThread()); |
| 90 observer_list_.RemoveObserver(observer); | 105 observer_list_.RemoveObserver(observer); |
| 91 } | 106 } |
| 92 | 107 |
| 93 void ArcServiceManager::Shutdown() { | 108 void ArcServiceManager::Shutdown() { |
| 94 DCHECK(thread_checker_.CalledOnValidThread()); | 109 DCHECK(thread_checker_.CalledOnValidThread()); |
| 95 | 110 |
| 96 // Before actual shutdown, notify observers for clean up. | 111 // Before actual shutdown, notify observers for clean up. |
| 97 for (auto& observer : observer_list_) | 112 for (auto& observer : observer_list_) |
| 98 observer.OnArcShutdown(); | 113 observer.OnArcShutdown(); |
| 99 | 114 |
| 100 icon_loader_ = nullptr; | 115 icon_loader_ = nullptr; |
| 101 activity_resolver_ = nullptr; | 116 activity_resolver_ = nullptr; |
| 102 services_.clear(); | 117 services_.clear(); |
| 118 named_services_.clear(); | |
| 103 } | 119 } |
| 104 | 120 |
| 105 } // namespace arc | 121 } // namespace arc |
| OLD | NEW |