| 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/renderer/metrics_render_frame_observer.h" | 5 #include "components/page_load_metrics/renderer/metrics_render_frame_observer.h" |
| 6 | 6 |
| 7 #include "base/time/time.h" | 7 #include "base/time/time.h" |
| 8 #include "base/timer/timer.h" | 8 #include "base/timer/timer.h" |
| 9 #include "components/page_load_metrics/renderer/page_timing_metrics_sender.h" | 9 #include "components/page_load_metrics/renderer/page_timing_metrics_sender.h" |
| 10 #include "content/public/renderer/render_frame.h" | 10 #include "content/public/renderer/render_frame.h" |
| 11 #include "third_party/WebKit/public/platform/WebURLResponse.h" | 11 #include "third_party/WebKit/public/platform/WebURLResponse.h" |
| 12 #include "third_party/WebKit/public/web/WebDataSource.h" | 12 #include "third_party/WebKit/public/web/WebDataSource.h" |
| 13 #include "third_party/WebKit/public/web/WebDocument.h" | 13 #include "third_party/WebKit/public/web/WebDocument.h" |
| 14 #include "third_party/WebKit/public/web/WebLocalFrame.h" | 14 #include "third_party/WebKit/public/web/WebLocalFrame.h" |
| 15 #include "third_party/WebKit/public/web/WebPerformance.h" | 15 #include "third_party/WebKit/public/web/WebPerformance.h" |
| 16 #include "url/gurl.h" | 16 #include "url/gurl.h" |
| 17 | 17 |
| 18 namespace page_load_metrics { | 18 namespace page_load_metrics { |
| 19 | 19 |
| 20 namespace { | 20 namespace { |
| 21 | 21 |
| 22 base::TimeDelta ClampDelta(double event, double start) { | 22 base::TimeDelta ClampDelta(double event, double start) { |
| 23 if (event - start < 0) | 23 if (event - start < 0) |
| 24 event = start; | 24 event = start; |
| 25 return base::Time::FromDoubleT(event) - base::Time::FromDoubleT(start); | 25 return base::Time::FromDoubleT(event) - base::Time::FromDoubleT(start); |
| 26 } | 26 } |
| 27 | 27 |
| 28 } // namespace | 28 } // namespace |
| 29 | 29 |
| 30 MetricsRenderFrameObserver::MetricsRenderFrameObserver( | 30 MetricsRenderFrameObserver::MetricsRenderFrameObserver( |
| 31 content::RenderFrame* render_frame) | 31 content::RenderFrame* render_frame) |
| 32 : content::RenderFrameObserver(render_frame) {} | 32 : content::RenderFrameObserver(render_frame) {} |
| 33 | 33 |
| 34 MetricsRenderFrameObserver::~MetricsRenderFrameObserver() {} | 34 MetricsRenderFrameObserver::~MetricsRenderFrameObserver() {} |
| 35 | 35 |
| 36 void MetricsRenderFrameObserver::DidChangePerformanceTiming() { | 36 void MetricsRenderFrameObserver::DidChangePerformanceTiming() { |
| 37 SendMetrics(); | 37 SendMetrics(); |
| 38 } | 38 } |
| (...skipping 74 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 113 timing.load_event_start = ClampDelta(perf.loadEventStart(), start); | 113 timing.load_event_start = ClampDelta(perf.loadEventStart(), start); |
| 114 timing.first_layout = ClampDelta(perf.firstLayout(), start); | 114 timing.first_layout = ClampDelta(perf.firstLayout(), start); |
| 115 return timing; | 115 return timing; |
| 116 } | 116 } |
| 117 | 117 |
| 118 scoped_ptr<base::Timer> MetricsRenderFrameObserver::CreateTimer() const { | 118 scoped_ptr<base::Timer> MetricsRenderFrameObserver::CreateTimer() const { |
| 119 return make_scoped_ptr(new base::OneShotTimer); | 119 return make_scoped_ptr(new base::OneShotTimer); |
| 120 } | 120 } |
| 121 | 121 |
| 122 } // namespace page_load_metrics | 122 } // namespace page_load_metrics |
| OLD | NEW |