diff -r 000000000000 -r 6474c204b198 dom/base/PerformanceResourceTiming.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/dom/base/PerformanceResourceTiming.h Wed Dec 31 06:09:35 2014 +0100 @@ -0,0 +1,133 @@ +/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ +/* This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +#ifndef mozilla_dom_PerformanceResourceTiming_h___ +#define mozilla_dom_PerformanceResourceTiming_h___ + +#include "nsCOMPtr.h" +#include "nsPerformance.h" +#include "nsIChannel.h" +#include "nsITimedChannel.h" +#include "nsDOMNavigationTiming.h" +#include "PerformanceEntry.h" + +namespace mozilla { +namespace dom { + +// http://www.w3.org/TR/resource-timing/#performanceresourcetiming +class PerformanceResourceTiming MOZ_FINAL : public PerformanceEntry +{ +public: + typedef mozilla::TimeStamp TimeStamp; + + NS_DECL_ISUPPORTS_INHERITED + NS_DECL_CYCLE_COLLECTION_SCRIPT_HOLDER_CLASS_INHERITED( + PerformanceResourceTiming, + PerformanceEntry) + + PerformanceResourceTiming(nsPerformanceTiming* aPerformanceTiming, + nsPerformance* aPerformance); + virtual ~PerformanceResourceTiming(); + + virtual JSObject* WrapObject(JSContext* aCx) MOZ_OVERRIDE; + + + virtual DOMHighResTimeStamp StartTime() const; + + virtual DOMHighResTimeStamp Duration() const + { + return ResponseEnd() - StartTime(); + } + + void GetInitiatorType(nsAString& aInitiatorType) const + { + aInitiatorType = mInitiatorType; + } + + void SetInitiatorType(const nsAString& aInitiatorType) + { + mInitiatorType = aInitiatorType; + } + + DOMHighResTimeStamp FetchStart() const { + return mTiming + ? mTiming->FetchStartHighRes() + : 0; + } + + DOMHighResTimeStamp RedirectStart() const { + // We have to check if all the redirect URIs had the same origin (since + // there is no check in RedirectEndHighRes()) + return mTiming && mTiming->IsSameOriginAsReferral() + ? mTiming->RedirectStartHighRes() + : 0; + } + + DOMHighResTimeStamp RedirectEnd() const { + // We have to check if all the redirect URIs had the same origin (since + // there is no check in RedirectEndHighRes()) + return mTiming && mTiming->IsSameOriginAsReferral() + ? mTiming->RedirectEndHighRes() + : 0; + } + + DOMHighResTimeStamp DomainLookupStart() const { + return mTiming && mTiming->IsSameOriginAsReferral() + ? mTiming->DomainLookupStartHighRes() + : 0; + } + + DOMHighResTimeStamp DomainLookupEnd() const { + return mTiming && mTiming->IsSameOriginAsReferral() + ? mTiming->DomainLookupEndHighRes() + : 0; + } + + DOMHighResTimeStamp ConnectStart() const { + return mTiming && mTiming->IsSameOriginAsReferral() + ? mTiming->ConnectStartHighRes() + : 0; + } + + DOMHighResTimeStamp ConnectEnd() const { + return mTiming && mTiming->IsSameOriginAsReferral() + ? mTiming->ConnectEndHighRes() + : 0; + } + + DOMHighResTimeStamp RequestStart() const { + return mTiming && mTiming->IsSameOriginAsReferral() + ? mTiming->RequestStartHighRes() + : 0; + } + + DOMHighResTimeStamp ResponseStart() const { + return mTiming && mTiming->IsSameOriginAsReferral() + ? mTiming->ResponseStartHighRes() + : 0; + } + + DOMHighResTimeStamp ResponseEnd() const { + return mTiming + ? mTiming->ResponseEndHighRes() + : 0; + } + + DOMHighResTimeStamp SecureConnectionStart() const + { + // This measurement is not available for Navigation Timing either. + // There is a different bug submitted for it. + return 0; + } + +protected: + nsString mInitiatorType; + nsRefPtr mTiming; +}; + +} // namespace dom +} // namespace mozilla + +#endif /* mozilla_dom_PerformanceResourceTiming_h___ */