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 "chrome/browser/media/router/issues_observer.h" | 5 #include "chrome/browser/media/router/issues_observer.h" |
| 6 | 6 |
| 7 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 #include "chrome/browser/media/router/media_router.h" | 8 #include "chrome/browser/media/router/media_router.h" |
| 9 | 9 |
| 10 namespace media_router { | 10 namespace media_router { |
| 11 | 11 |
| 12 IssuesObserver::IssuesObserver(MediaRouter* router) : router_(router) { | 12 IssuesObserver::IssuesObserver(MediaRouter* router) |
| 13 : router_(router), initialized_(false) { | |
| 13 DCHECK(router_); | 14 DCHECK(router_); |
| 14 } | 15 } |
| 15 | 16 |
| 16 IssuesObserver::~IssuesObserver() { | 17 IssuesObserver::~IssuesObserver() { |
| 18 if (initialized_) | |
| 19 router_->UnregisterIssuesObserver(this); | |
| 17 } | 20 } |
| 18 | 21 |
| 19 void IssuesObserver::RegisterObserver() { | 22 void IssuesObserver::Init() { |
| 23 if (initialized_) | |
| 24 return; | |
| 25 | |
| 20 router_->RegisterIssuesObserver(this); | 26 router_->RegisterIssuesObserver(this); |
| 21 } | 27 initialized_ = true; |
|
dcheng
2016/12/07 18:58:02
Can you help me understand why this isn't just par
imcheng
2016/12/09 23:19:53
RegisterIssuesObserver will synchronously invoke O
| |
| 22 | |
| 23 void IssuesObserver::UnregisterObserver() { | |
| 24 router_->UnregisterIssuesObserver(this); | |
| 25 } | 28 } |
| 26 | 29 |
| 27 } // namespace media_router | 30 } // namespace media_router |
| OLD | NEW |