OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2012 Google Inc. All rights reserved. | 2 * Copyright (C) 2012 Google Inc. All rights reserved. |
3 * Copyright (C) 2012 Intel Inc. All rights reserved. | 3 * Copyright (C) 2012 Intel Inc. All rights reserved. |
4 * | 4 * |
5 * Redistribution and use in source and binary forms, with or without | 5 * Redistribution and use in source and binary forms, with or without |
6 * modification, are permitted provided that the following conditions are | 6 * modification, are permitted provided that the following conditions are |
7 * met: | 7 * met: |
8 * | 8 * |
9 * * Redistributions of source code must retain the above copyright | 9 * * Redistributions of source code must retain the above copyright |
10 * notice, this list of conditions and the following disclaimer. | 10 * notice, this list of conditions and the following disclaimer. |
(...skipping 14 matching lines...) Expand all Loading... |
25 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | 25 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
26 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | 26 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
27 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 27 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
28 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 28 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
29 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 29 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
30 */ | 30 */ |
31 | 31 |
32 #include "config.h" | 32 #include "config.h" |
33 #include "core/timing/PerformanceResourceTiming.h" | 33 #include "core/timing/PerformanceResourceTiming.h" |
34 | 34 |
| 35 #include "core/timing/PerformanceBase.h" |
35 #include "platform/network/ResourceRequest.h" | 36 #include "platform/network/ResourceRequest.h" |
36 #include "platform/network/ResourceResponse.h" | 37 #include "platform/network/ResourceResponse.h" |
37 #include "platform/network/ResourceTimingInfo.h" | 38 #include "platform/network/ResourceTimingInfo.h" |
38 | 39 |
39 namespace blink { | 40 namespace blink { |
40 | 41 |
41 static double monotonicTimeToDOMHighResTimeStamp(double timeOrigin, double secon
ds) | 42 static double monotonicTimeToDOMHighResTimeStamp(double timeOrigin, double secon
ds) |
42 { | 43 { |
43 ASSERT(seconds >= 0.0); | 44 ASSERT(seconds >= 0.0); |
44 if (!seconds) | 45 if (!seconds) |
45 return 0.0; | 46 return 0.0; |
46 return (seconds - timeOrigin) * 1000.0; | 47 return PerformanceBase::clampTimeResolution(seconds - timeOrigin) * 1000.0; |
47 } | 48 } |
48 | 49 |
49 PerformanceResourceTiming::PerformanceResourceTiming(const ResourceTimingInfo& i
nfo, double timeOrigin, double startTime, double lastRedirectEndTime, bool allow
TimingDetails, bool allowRedirectDetails) | 50 PerformanceResourceTiming::PerformanceResourceTiming(const ResourceTimingInfo& i
nfo, double timeOrigin, double startTime, double lastRedirectEndTime, bool allow
TimingDetails, bool allowRedirectDetails) |
50 : PerformanceEntry(info.initialRequest().url().string(), "resource", monoton
icTimeToDOMHighResTimeStamp(timeOrigin, startTime), monotonicTimeToDOMHighResTim
eStamp(timeOrigin, info.loadFinishTime())) | 51 : PerformanceEntry(info.initialRequest().url().string(), "resource", monoton
icTimeToDOMHighResTimeStamp(timeOrigin, startTime), monotonicTimeToDOMHighResTim
eStamp(timeOrigin, info.loadFinishTime())) |
51 , m_initiatorType(info.initiatorType()) | 52 , m_initiatorType(info.initiatorType()) |
52 , m_timeOrigin(timeOrigin) | 53 , m_timeOrigin(timeOrigin) |
53 , m_timing(info.finalResponse().resourceLoadTiming()) | 54 , m_timing(info.finalResponse().resourceLoadTiming()) |
54 , m_lastRedirectEndTime(lastRedirectEndTime) | 55 , m_lastRedirectEndTime(lastRedirectEndTime) |
55 , m_finishTime(info.loadFinishTime()) | 56 , m_finishTime(info.loadFinishTime()) |
56 , m_didReuseConnection(info.finalResponse().connectionReused()) | 57 , m_didReuseConnection(info.finalResponse().connectionReused()) |
(...skipping 148 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
205 | 206 |
206 double PerformanceResourceTiming::responseEnd() const | 207 double PerformanceResourceTiming::responseEnd() const |
207 { | 208 { |
208 if (!m_finishTime) | 209 if (!m_finishTime) |
209 return responseStart(); | 210 return responseStart(); |
210 | 211 |
211 return monotonicTimeToDOMHighResTimeStamp(m_timeOrigin, m_finishTime); | 212 return monotonicTimeToDOMHighResTimeStamp(m_timeOrigin, m_finishTime); |
212 } | 213 } |
213 | 214 |
214 } // namespace blink | 215 } // namespace blink |
OLD | NEW |