Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(25)

Side by Side Diff: services/resource_coordinator/coordination_unit/coordination_unit_manager.cc

Issue 2926663003: [GRC] Coordination Unit Graph Observer (Closed)
Patch Set: Rebase Created 3 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2017 The Chromium Authors. All rights reserved. 1 // Copyright 2017 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 "services/resource_coordinator/coordination_unit/coordination_unit_mana ger.h" 5 #include "services/resource_coordinator/coordination_unit/coordination_unit_mana ger.h"
6 6
7 #include <memory>
8
7 #include "base/bind.h" 9 #include "base/bind.h"
8 #include "base/bind_helpers.h" 10 #include "base/bind_helpers.h"
11 #include "base/macros.h"
12 #include "services/resource_coordinator/coordination_unit/coordination_unit_grap h_observer.h"
13 #include "services/resource_coordinator/coordination_unit/coordination_unit_impl .h"
9 #include "services/resource_coordinator/coordination_unit/coordination_unit_prov ider_impl.h" 14 #include "services/resource_coordinator/coordination_unit/coordination_unit_prov ider_impl.h"
15 #include "services/resource_coordinator/public/cpp/coordination_unit_types.h"
10 #include "services/service_manager/public/cpp/binder_registry.h" 16 #include "services/service_manager/public/cpp/binder_registry.h"
11 #include "services/service_manager/public/cpp/service_context.h" 17 #include "services/service_manager/public/cpp/service_context.h"
12 18
13 namespace resource_coordinator { 19 namespace resource_coordinator {
14 20
15 class CoordinationUnitImpl;
16
17 CoordinationUnitManager::CoordinationUnitManager() = default; 21 CoordinationUnitManager::CoordinationUnitManager() = default;
18 22
19 CoordinationUnitManager::~CoordinationUnitManager() = default; 23 CoordinationUnitManager::~CoordinationUnitManager() {
24 for (CoordinationUnitGraphObserver* observer : observers_) {
25 delete observer;
26 }
27 }
20 28
21 void CoordinationUnitManager::OnStart( 29 void CoordinationUnitManager::OnStart(
22 service_manager::BinderRegistry* registry, 30 service_manager::BinderRegistry* registry,
23 service_manager::ServiceContextRefFactory* service_ref_factory) { 31 service_manager::ServiceContextRefFactory* service_ref_factory) {
24 registry->AddInterface(base::Bind(&CoordinationUnitProviderImpl::Create, 32 registry->AddInterface(base::Bind(&CoordinationUnitProviderImpl::Create,
25 base::Unretained(service_ref_factory))); 33 base::Unretained(service_ref_factory),
34 base::Unretained(this)));
35 }
36
37 void CoordinationUnitManager::RegisterObserver(
38 CoordinationUnitGraphObserver* observer) {
39 observers_.push_back(observer);
40 }
41
42 void CoordinationUnitManager::NotifyObserversCoordinationUnitCreated(
43 CoordinationUnitImpl* coordination_unit) {
44 for (CoordinationUnitGraphObserver* observer : observers_) {
45 if (observer->filter() == coordination_unit->id().type ||
46 // CoordinationUnitType::kInvalidType overrides filtering.
47 observer->filter() == CoordinationUnitType::kInvalidType) {
Zhen Wang 2017/06/15 20:07:53 This is not intuitive. See comments in CUGraphObse
48 observer->CoordinationUnitCreated(coordination_unit);
49 }
50 }
51 }
52
53 void CoordinationUnitManager::NotifyObserversCoordinationUnitWillBeDestroyed(
54 CoordinationUnitImpl* coordination_unit) {
55 coordination_unit->WillBeDestroyed();
56 }
57
58 void CoordinationUnitManager::UnregisterAllObserversForTesting() {
59 observers_.clear();
26 } 60 }
27 61
28 } // namespace resource_coordinator 62 } // namespace resource_coordinator
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698