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_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 |