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 |