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

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

Issue 2942403002: [GRC] Coordination Unit Graph Observer (Closed)
Patch Set: Address reviewer feedback 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 #include <utility> 7 #include <utility>
9 8
10 #include "base/bind.h" 9 #include "base/bind.h"
11 #include "base/bind_helpers.h" 10 #include "base/bind_helpers.h"
12 #include "base/macros.h" 11 #include "base/macros.h"
13 #include "services/resource_coordinator/coordination_unit/coordination_unit_grap h_observer.h" 12 #include "services/resource_coordinator/coordination_unit/coordination_unit_grap h_observer.h"
14 #include "services/resource_coordinator/coordination_unit/coordination_unit_impl .h" 13 #include "services/resource_coordinator/coordination_unit/coordination_unit_impl .h"
15 #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"
16 #include "services/resource_coordinator/public/cpp/coordination_unit_types.h" 15 #include "services/resource_coordinator/public/cpp/coordination_unit_types.h"
17 #include "services/service_manager/public/cpp/binder_registry.h" 16 #include "services/service_manager/public/cpp/binder_registry.h"
(...skipping 11 matching lines...) Expand all
29 registry->AddInterface(base::Bind(&CoordinationUnitProviderImpl::Create, 28 registry->AddInterface(base::Bind(&CoordinationUnitProviderImpl::Create,
30 base::Unretained(service_ref_factory), 29 base::Unretained(service_ref_factory),
31 base::Unretained(this))); 30 base::Unretained(this)));
32 } 31 }
33 32
34 void CoordinationUnitManager::RegisterObserver( 33 void CoordinationUnitManager::RegisterObserver(
35 std::unique_ptr<CoordinationUnitGraphObserver> observer) { 34 std::unique_ptr<CoordinationUnitGraphObserver> observer) {
36 observers_.push_back(std::move(observer)); 35 observers_.push_back(std::move(observer));
37 } 36 }
38 37
39 void CoordinationUnitManager::NotifyObserversCoordinationUnitCreated( 38 void CoordinationUnitManager::OnCoordinationUnitCreated(
40 CoordinationUnitImpl* coordination_unit) { 39 CoordinationUnitImpl* coordination_unit) {
41 for (auto& observer : observers_) { 40 for (auto& observer : observers_) {
42 if (observer->ShouldObserve(coordination_unit)) { 41 if (observer->ShouldObserve(coordination_unit)) {
43 observer->OnCoordinationUnitCreatedEvent(coordination_unit); 42 coordination_unit->AddObserver(observer.get());
43 observer->OnCoordinationUnitCreated(coordination_unit);
44 } 44 }
45 } 45 }
46 } 46 }
47 47
48 void CoordinationUnitManager::NotifyObserversCoordinationUnitWillBeDestroyed( 48 void CoordinationUnitManager::OnCoordinationUnitWillBeDestroyed(
49 CoordinationUnitImpl* coordination_unit) { 49 CoordinationUnitImpl* coordination_unit) {
50 coordination_unit->WillBeDestroyed(); 50 for (auto& observer : observers_) {
51 if (observer->ShouldObserve(coordination_unit)) {
52 observer->OnCoordinationUnitWillBeDestroyed(coordination_unit);
matthalp 2017/06/20 21:02:09 I advocate moving the OnCoordinationUnitWillBeDest
53 }
54 }
51 } 55 }
52 56
53 } // namespace resource_coordinator 57 } // namespace resource_coordinator
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698