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/page_load_metrics/browser/page_load_metrics_observer.h" | 5 #include "components/page_load_metrics/browser/page_load_metrics_observer.h" |
| 6 | 6 |
| 7 namespace page_load_metrics { | 7 namespace page_load_metrics { |
| 8 | 8 |
| 9 PageLoadExtraInfo::PageLoadExtraInfo( | 9 PageLoadExtraInfo::PageLoadExtraInfo( |
| 10 const base::TimeDelta& first_background_time, | 10 const base::TimeDelta& first_background_time, |
| 11 const base::TimeDelta& first_foreground_time, | 11 const base::TimeDelta& first_foreground_time, |
| 12 bool started_in_foreground) | 12 bool started_in_foreground, |
| 13 bool has_commit) | |
| 13 : first_background_time(first_background_time), | 14 : first_background_time(first_background_time), |
| 14 first_foreground_time(first_foreground_time), | 15 first_foreground_time(first_foreground_time), |
| 15 started_in_foreground(started_in_foreground) {} | 16 started_in_foreground(started_in_foreground), |
| 17 has_commit(has_commit) {} | |
| 18 | |
| 19 PageLoadMetricsObserver::PageLoadMetricsObserver() : observable_(nullptr) {} | |
| 20 | |
| 21 PageLoadMetricsObserver::PageLoadMetricsObserver( | |
| 22 PageLoadMetricsObservable* observable) | |
| 23 : observable_(observable) { | |
| 24 observable_->AddObserver(this); | |
| 25 } | |
| 26 | |
| 27 void PageLoadMetricsObserver::OnPageLoadMetricsGoingAway() { | |
| 28 Destroy(); | |
| 29 } | |
| 30 | |
| 31 void PageLoadMetricsObserver::Destroy() { | |
| 32 if (observable_) | |
|
Bryan McQuade
2015/11/30 19:18:48
what happens if someone calls MWCO::RemoveObserver
Charlie Harrison
2015/11/30 22:22:02
I really like having the Observable own the observ
| |
| 33 observable_->RemoveObserver(this); | |
| 34 delete this; | |
| 35 } | |
| 36 | |
| 37 void PageLoadMetricsObserver::Observe(PageLoadMetricsObservable* observable) { | |
| 38 observable_ = observable; | |
| 39 observable->AddObserver(this); | |
| 40 } | |
| 41 | |
| 42 void PageLoadMetricsObserver::StopObserving() { | |
| 43 DCHECK(observable_); | |
| 44 observable_->RemoveObserver(this); | |
| 45 observable_ = nullptr; | |
| 46 } | |
| 16 | 47 |
| 17 } // namespace page_load_metrics | 48 } // namespace page_load_metrics |
| OLD | NEW |