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_util.h" | 5 #include "components/page_load_metrics/browser/page_load_metrics_util.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 | 8 |
9 #include "components/page_load_metrics/browser/page_load_metrics_observer.h" | 9 #include "components/page_load_metrics/browser/page_load_metrics_observer.h" |
10 #include "components/page_load_metrics/common/page_load_timing.h" | 10 #include "components/page_load_metrics/common/page_load_timing.h" |
11 | 11 |
12 namespace page_load_metrics { | 12 namespace page_load_metrics { |
13 | 13 |
14 bool WasStartedInForegroundEventInForeground(base::TimeDelta event, | 14 bool WasStartedInForegroundEventInForeground(base::TimeDelta event, |
15 const PageLoadExtraInfo& info) { | 15 const PageLoadExtraInfo& info) { |
16 return info.started_in_foreground && !event.is_zero() && | 16 return info.started_in_foreground && !event.is_zero() && |
17 (info.first_background_time.is_zero() || | 17 (!info.first_background_time || |
18 event < info.first_background_time); | 18 event <= info.first_background_time.value()); |
19 } | |
20 | |
21 // TODO (@shivanisha) Since the above function is called for | |
Charlie Harrison
2016/05/19 18:20:49
"TODO(shivanisha):" Is the preferred syntax.
| |
22 // TimeDelta coming over IPC (PageLoadTiming) and since Optional is not | |
Charlie Harrison
2016/05/19 18:20:49
This sentence is a little awkward. What about:
"T
shivanisha
2016/05/23 15:06:44
sounds good. done
| |
23 // currently supported in IPC, thus creating another function. | |
24 // They should ideally converge to one function in the future | |
25 // when either the serialization framework supports Optional or we send | |
26 // actual timestamps over IPC and compute deltas in browser process. | |
27 bool WasStartedInForegroundOptionalEventInForeground( | |
28 const base::Optional<base::TimeDelta>& event, | |
29 const PageLoadExtraInfo& info) { | |
30 return info.started_in_foreground && event && | |
31 (!info.first_background_time || | |
32 event.value() <= info.first_background_time.value()); | |
19 } | 33 } |
20 | 34 |
21 bool WasParseInForeground(base::TimeDelta parse_start, | 35 bool WasParseInForeground(base::TimeDelta parse_start, |
22 base::TimeDelta parse_stop, | 36 base::TimeDelta parse_stop, |
23 const PageLoadExtraInfo& info) { | 37 const PageLoadExtraInfo& info) { |
24 if (parse_start.is_zero()) { | 38 if (parse_start.is_zero()) { |
25 return false; | 39 return false; |
26 } | 40 } |
27 const bool incomplete_parse_in_foreground = | 41 const bool incomplete_parse_in_foreground = parse_stop.is_zero() && |
28 parse_stop.is_zero() && info.started_in_foreground && | 42 info.started_in_foreground && |
29 info.first_background_time.is_zero(); | 43 !info.first_background_time; |
30 | 44 |
31 return incomplete_parse_in_foreground || | 45 return incomplete_parse_in_foreground || |
32 WasStartedInForegroundEventInForeground(parse_stop, info); | 46 WasStartedInForegroundEventInForeground(parse_stop, info); |
33 } | 47 } |
34 } // namespace page_load_metrics | 48 } // namespace page_load_metrics |
OLD | NEW |