Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(426)

Unified Diff: Source/core/timing/Performance.cpp

Issue 1100813004: Offer User Timing in workers (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: rebase Created 5 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « Source/core/timing/Performance.h ('k') | Source/core/timing/PerformanceBase.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: Source/core/timing/Performance.cpp
diff --git a/Source/core/timing/Performance.cpp b/Source/core/timing/Performance.cpp
index 2f4c7c2797280f1cd5c9b6b49a391d5d8ac51457..2f799b7fcdae505bc6a6a1878c885f901279f44a 100644
--- a/Source/core/timing/Performance.cpp
+++ b/Source/core/timing/Performance.cpp
@@ -33,29 +33,15 @@
#include "core/timing/Performance.h"
#include "core/dom/Document.h"
-#include "core/events/Event.h"
#include "core/frame/LocalFrame.h"
#include "core/loader/DocumentLoader.h"
-#include "core/timing/PerformanceCompositeTiming.h"
-#include "core/timing/PerformanceRenderTiming.h"
-#include "core/timing/PerformanceResourceTiming.h"
#include "core/timing/PerformanceTiming.h"
-#include "core/timing/PerformanceUserTiming.h"
-#include "core/timing/ResourceTimingInfo.h"
-#include "platform/weborigin/SecurityOrigin.h"
-#include "wtf/CurrentTime.h"
namespace blink {
-static const size_t defaultResourceTimingBufferSize = 150;
-static const size_t defaultFrameTimingBufferSize = 150;
-
Performance::Performance(LocalFrame* frame)
- : DOMWindowProperty(frame)
- , m_frameTimingBufferSize(defaultFrameTimingBufferSize)
- , m_resourceTimingBufferSize(defaultResourceTimingBufferSize)
- , m_referenceTime(frame && frame->host() ? frame->document()->loader()->timing().referenceMonotonicTime() : 0.0)
- , m_userTiming(nullptr)
+ : PerformanceBase(frame && frame->host() ? frame->document()->loader()->timing().referenceMonotonicTime() : 0.0)
+ , DOMWindowProperty(frame)
{
}
@@ -63,11 +49,6 @@ Performance::~Performance()
{
}
-const AtomicString& Performance::interfaceName() const
-{
- return EventTargetNames::Performance;
-}
-
ExecutionContext* Performance::executionContext() const
{
if (!frame())
@@ -98,266 +79,13 @@ PerformanceTiming* Performance::timing() const
return m_timing.get();
}
-PerformanceEntryVector Performance::getEntries() const
-{
- PerformanceEntryVector entries;
-
- entries.appendVector(m_resourceTimingBuffer);
- entries.appendVector(m_frameTimingBuffer);
-
- if (m_userTiming) {
- entries.appendVector(m_userTiming->getMarks());
- entries.appendVector(m_userTiming->getMeasures());
- }
-
- std::sort(entries.begin(), entries.end(), PerformanceEntry::startTimeCompareLessThan);
- return entries;
-}
-
-PerformanceEntryVector Performance::getEntriesByType(const String& entryType)
-{
- PerformanceEntryVector entries;
-
- if (equalIgnoringCase(entryType, "resource")) {
- for (const auto& resource : m_resourceTimingBuffer)
- entries.append(resource);
- }
-
- if (equalIgnoringCase(entryType, "composite")
- || equalIgnoringCase(entryType, "render")) {
- for (const auto& frame : m_frameTimingBuffer) {
- if (equalIgnoringCase(entryType, frame->entryType())) {
- entries.append(frame);
- }
- }
- }
-
- if (m_userTiming) {
- if (equalIgnoringCase(entryType, "mark"))
- entries.appendVector(m_userTiming->getMarks());
- else if (equalIgnoringCase(entryType, "measure"))
- entries.appendVector(m_userTiming->getMeasures());
- }
-
- std::sort(entries.begin(), entries.end(), PerformanceEntry::startTimeCompareLessThan);
- return entries;
-}
-
-PerformanceEntryVector Performance::getEntriesByName(const String& name, const String& entryType)
-{
- PerformanceEntryVector entries;
-
- if (entryType.isNull() || equalIgnoringCase(entryType, "resource")) {
- for (const auto& resource : m_resourceTimingBuffer) {
- if (resource->name() == name)
- entries.append(resource);
- }
- }
-
- if (entryType.isNull() || equalIgnoringCase(entryType, "composite")
- || equalIgnoringCase(entryType, "render")) {
- for (const auto& frame : m_frameTimingBuffer) {
- if (frame->name() == name && (entryType.isNull()
- || equalIgnoringCase(entryType, frame->entryType()))) {
- entries.append(frame);
- }
- }
- }
-
- if (m_userTiming) {
- if (entryType.isNull() || equalIgnoringCase(entryType, "mark"))
- entries.appendVector(m_userTiming->getMarks(name));
- if (entryType.isNull() || equalIgnoringCase(entryType, "measure"))
- entries.appendVector(m_userTiming->getMeasures(name));
- }
-
- std::sort(entries.begin(), entries.end(), PerformanceEntry::startTimeCompareLessThan);
- return entries;
-}
-
-void Performance::webkitClearResourceTimings()
-{
- m_resourceTimingBuffer.clear();
-}
-
-void Performance::webkitSetResourceTimingBufferSize(unsigned size)
-{
- m_resourceTimingBufferSize = size;
- if (isResourceTimingBufferFull())
- dispatchEvent(Event::create(EventTypeNames::webkitresourcetimingbufferfull));
-}
-
-void Performance::clearFrameTimings()
-{
- m_frameTimingBuffer.clear();
-}
-
-void Performance::setFrameTimingBufferSize(unsigned size)
-{
- m_frameTimingBufferSize = size;
- if (isFrameTimingBufferFull())
- dispatchEvent(Event::create(EventTypeNames::frametimingbufferfull));
-}
-
-static bool passesTimingAllowCheck(const ResourceResponse& response, Document* requestingDocument, const AtomicString& originalTimingAllowOrigin)
-{
- AtomicallyInitializedStaticReference(AtomicString, timingAllowOrigin, new AtomicString("timing-allow-origin"));
-
- RefPtr<SecurityOrigin> resourceOrigin = SecurityOrigin::create(response.url());
- if (resourceOrigin->isSameSchemeHostPort(requestingDocument->securityOrigin()))
- return true;
-
- const AtomicString& timingAllowOriginString = originalTimingAllowOrigin.isEmpty() ? response.httpHeaderField(timingAllowOrigin) : originalTimingAllowOrigin;
- if (timingAllowOriginString.isEmpty() || equalIgnoringCase(timingAllowOriginString, "null"))
- return false;
-
- if (timingAllowOriginString == starAtom)
- return true;
-
- const String& securityOrigin = requestingDocument->securityOrigin()->toString();
- Vector<String> timingAllowOrigins;
- timingAllowOriginString.string().split(' ', timingAllowOrigins);
- for (const String& allowOrigin : timingAllowOrigins) {
- if (allowOrigin == securityOrigin)
- return true;
- }
-
- return false;
-}
-
-static bool allowsTimingRedirect(const Vector<ResourceResponse>& redirectChain, const ResourceResponse& finalResponse, Document* initiatorDocument)
-{
- if (!passesTimingAllowCheck(finalResponse, initiatorDocument, emptyAtom))
- return false;
-
- for (const ResourceResponse& response : redirectChain) {
- if (!passesTimingAllowCheck(response, initiatorDocument, emptyAtom))
- return false;
- }
-
- return true;
-}
-
-void Performance::addResourceTiming(const ResourceTimingInfo& info, Document* initiatorDocument)
-{
- if (isResourceTimingBufferFull())
- return;
-
- const ResourceResponse& finalResponse = info.finalResponse();
- bool allowTimingDetails = passesTimingAllowCheck(finalResponse, initiatorDocument, info.originalTimingAllowOrigin());
- double startTime = info.initialTime();
-
- if (info.redirectChain().isEmpty()) {
- PerformanceEntry* entry = PerformanceResourceTiming::create(info, initiatorDocument, startTime, allowTimingDetails);
- addResourceTimingBuffer(entry);
- return;
- }
-
- const Vector<ResourceResponse>& redirectChain = info.redirectChain();
- bool allowRedirectDetails = allowsTimingRedirect(redirectChain, finalResponse, initiatorDocument);
-
- if (!allowRedirectDetails) {
- ResourceLoadTiming* finalTiming = finalResponse.resourceLoadTiming();
- ASSERT(finalTiming);
- if (finalTiming)
- startTime = finalTiming->requestTime();
- }
-
- ResourceLoadTiming* lastRedirectTiming = redirectChain.last().resourceLoadTiming();
- ASSERT(lastRedirectTiming);
- double lastRedirectEndTime = lastRedirectTiming->receiveHeadersEnd();
-
- PerformanceEntry* entry = PerformanceResourceTiming::create(info, initiatorDocument, startTime, lastRedirectEndTime, allowTimingDetails, allowRedirectDetails);
- addResourceTimingBuffer(entry);
-}
-
-void Performance::addResourceTimingBuffer(PerformanceEntry* entry)
-{
- m_resourceTimingBuffer.append(entry);
-
- if (isResourceTimingBufferFull())
- dispatchEvent(Event::create(EventTypeNames::webkitresourcetimingbufferfull));
-}
-
-bool Performance::isResourceTimingBufferFull()
-{
- return m_resourceTimingBuffer.size() >= m_resourceTimingBufferSize;
-}
-
-void Performance::addRenderTiming(Document* initiatorDocument, unsigned sourceFrame, double startTime, double finishTime)
-{
- if (isFrameTimingBufferFull())
- return;
-
- PerformanceEntry* entry = PerformanceRenderTiming::create(initiatorDocument, sourceFrame, startTime, finishTime);
- addFrameTimingBuffer(entry);
-}
-
-void Performance::addCompositeTiming(Document* initiatorDocument, unsigned sourceFrame, double startTime)
-{
- if (isFrameTimingBufferFull())
- return;
-
- PerformanceEntry* entry = PerformanceCompositeTiming::create(initiatorDocument, sourceFrame, startTime);
- addFrameTimingBuffer(entry);
-}
-
-void Performance::addFrameTimingBuffer(PerformanceEntry* entry)
-{
- m_frameTimingBuffer.append(entry);
-
- if (isFrameTimingBufferFull())
- dispatchEvent(Event::create(EventTypeNames::frametimingbufferfull));
-}
-
-bool Performance::isFrameTimingBufferFull()
-{
- return m_frameTimingBuffer.size() >= m_frameTimingBufferSize;
-}
-
-void Performance::mark(const String& markName, ExceptionState& exceptionState)
-{
- if (!m_userTiming)
- m_userTiming = UserTiming::create(this);
- m_userTiming->mark(markName, exceptionState);
-}
-
-void Performance::clearMarks(const String& markName)
-{
- if (!m_userTiming)
- m_userTiming = UserTiming::create(this);
- m_userTiming->clearMarks(markName);
-}
-
-void Performance::measure(const String& measureName, const String& startMark, const String& endMark, ExceptionState& exceptionState)
-{
- if (!m_userTiming)
- m_userTiming = UserTiming::create(this);
- m_userTiming->measure(measureName, startMark, endMark, exceptionState);
-}
-
-void Performance::clearMeasures(const String& measureName)
-{
- if (!m_userTiming)
- m_userTiming = UserTiming::create(this);
- m_userTiming->clearMeasures(measureName);
-}
-
-double Performance::now() const
-{
- return 1000.0 * (monotonicallyIncreasingTime() - m_referenceTime);
-}
-
DEFINE_TRACE(Performance)
{
visitor->trace(m_navigation);
visitor->trace(m_timing);
- visitor->trace(m_frameTimingBuffer);
- visitor->trace(m_resourceTimingBuffer);
visitor->trace(m_memoryInfo);
- visitor->trace(m_userTiming);
- EventTargetWithInlineData::trace(visitor);
DOMWindowProperty::trace(visitor);
+ PerformanceBase::trace(visitor);
}
} // namespace blink
« no previous file with comments | « Source/core/timing/Performance.h ('k') | Source/core/timing/PerformanceBase.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698