| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 2010 Google, Inc. All Rights Reserved. | 2 * Copyright (C) 2010 Google, Inc. All Rights Reserved. |
| 3 * | 3 * |
| 4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
| 5 * modification, are permitted provided that the following conditions | 5 * modification, are permitted provided that the following conditions |
| 6 * are met: | 6 * are met: |
| 7 * 1. Redistributions of source code must retain the above copyright | 7 * 1. Redistributions of source code must retain the above copyright |
| 8 * notice, this list of conditions and the following disclaimer. | 8 * notice, this list of conditions and the following disclaimer. |
| 9 * 2. Redistributions in binary form must reproduce the above copyright | 9 * 2. Redistributions in binary form must reproduce the above copyright |
| 10 * notice, this list of conditions and the following disclaimer in the | 10 * notice, this list of conditions and the following disclaimer in the |
| (...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 42 | 42 |
| 43 namespace blink { | 43 namespace blink { |
| 44 | 44 |
| 45 using namespace HTMLNames; | 45 using namespace HTMLNames; |
| 46 | 46 |
| 47 HTMLScriptRunner::HTMLScriptRunner(Document* document, HTMLScriptRunnerHost* hos
t) | 47 HTMLScriptRunner::HTMLScriptRunner(Document* document, HTMLScriptRunnerHost* hos
t) |
| 48 : m_document(document) | 48 : m_document(document) |
| 49 , m_host(host) | 49 , m_host(host) |
| 50 , m_scriptNestingLevel(0) | 50 , m_scriptNestingLevel(0) |
| 51 , m_hasScriptsWaitingForResources(false) | 51 , m_hasScriptsWaitingForResources(false) |
| 52 , m_parserBlockingScriptAlreadyLoaded(false) |
| 52 { | 53 { |
| 53 ASSERT(m_host); | 54 ASSERT(m_host); |
| 54 } | 55 } |
| 55 | 56 |
| 56 HTMLScriptRunner::~HTMLScriptRunner() | 57 HTMLScriptRunner::~HTMLScriptRunner() |
| 57 { | 58 { |
| 58 #if ENABLE(OILPAN) | 59 #if ENABLE(OILPAN) |
| 59 // If the document is destructed without having explicitly | 60 // If the document is destructed without having explicitly |
| 60 // detached the parser (and this script runner object), perform | 61 // detached the parser (and this script runner object), perform |
| 61 // detach steps now. This will happen if the Document, the parser | 62 // detach steps now. This will happen if the Document, the parser |
| (...skipping 56 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 118 ASSERT(m_document->isScriptExecutionReady()); | 119 ASSERT(m_document->isScriptExecutionReady()); |
| 119 ASSERT(isPendingScriptReady(m_parserBlockingScript)); | 120 ASSERT(isPendingScriptReady(m_parserBlockingScript)); |
| 120 | 121 |
| 121 InsertionPointRecord insertionPointRecord(m_host->inputStream()); | 122 InsertionPointRecord insertionPointRecord(m_host->inputStream()); |
| 122 executePendingScriptAndDispatchEvent(m_parserBlockingScript, PendingScriptBl
ockingParser); | 123 executePendingScriptAndDispatchEvent(m_parserBlockingScript, PendingScriptBl
ockingParser); |
| 123 } | 124 } |
| 124 | 125 |
| 125 void HTMLScriptRunner::executePendingScriptAndDispatchEvent(PendingScript& pendi
ngScript, PendingScriptType pendingScriptType) | 126 void HTMLScriptRunner::executePendingScriptAndDispatchEvent(PendingScript& pendi
ngScript, PendingScriptType pendingScriptType) |
| 126 { | 127 { |
| 127 bool errorOccurred = false; | 128 bool errorOccurred = false; |
| 129 double loadFinishTime = pendingScript.resource() ? pendingScript.resource()-
>loadFinishTime() : 0; |
| 128 ScriptSourceCode sourceCode = pendingScript.getSource(documentURLForScriptEx
ecution(m_document), errorOccurred); | 130 ScriptSourceCode sourceCode = pendingScript.getSource(documentURLForScriptEx
ecution(m_document), errorOccurred); |
| 129 | 131 |
| 130 // Stop watching loads before executeScript to prevent recursion if the scri
pt reloads itself. | 132 // Stop watching loads before executeScript to prevent recursion if the scri
pt reloads itself. |
| 131 pendingScript.stopWatchingForLoad(this); | 133 pendingScript.stopWatchingForLoad(this); |
| 132 | 134 |
| 133 if (!isExecutingScript()) { | 135 if (!isExecutingScript()) { |
| 134 Microtask::performCheckpoint(); | 136 Microtask::performCheckpoint(); |
| 135 if (pendingScriptType == PendingScriptBlockingParser) { | 137 if (pendingScriptType == PendingScriptBlockingParser) { |
| 136 m_hasScriptsWaitingForResources = !m_document->isScriptExecutionRead
y(); | 138 m_hasScriptsWaitingForResources = !m_document->isScriptExecutionRead
y(); |
| 137 // The parser cannot be unblocked as a microtask requested another r
esource | 139 // The parser cannot be unblocked as a microtask requested another r
esource |
| 138 if (m_hasScriptsWaitingForResources) | 140 if (m_hasScriptsWaitingForResources) |
| 139 return; | 141 return; |
| 140 } | 142 } |
| 141 } | 143 } |
| 142 | 144 |
| 143 // Clear the pending script before possible rentrancy from executeScript() | 145 // Clear the pending script before possible rentrancy from executeScript() |
| 144 RefPtrWillBeRawPtr<Element> element = pendingScript.releaseElementAndClear()
; | 146 RefPtrWillBeRawPtr<Element> element = pendingScript.releaseElementAndClear()
; |
| 147 double compilationFinishTime = 0; |
| 145 if (ScriptLoader* scriptLoader = toScriptLoaderIfPossible(element.get())) { | 148 if (ScriptLoader* scriptLoader = toScriptLoaderIfPossible(element.get())) { |
| 146 NestingLevelIncrementer nestingLevelIncrementer(m_scriptNestingLevel); | 149 NestingLevelIncrementer nestingLevelIncrementer(m_scriptNestingLevel); |
| 147 IgnoreDestructiveWriteCountIncrementer ignoreDestructiveWriteCountIncrem
enter(m_document); | 150 IgnoreDestructiveWriteCountIncrementer ignoreDestructiveWriteCountIncrem
enter(m_document); |
| 148 if (errorOccurred) | 151 if (errorOccurred) |
| 149 scriptLoader->dispatchErrorEvent(); | 152 scriptLoader->dispatchErrorEvent(); |
| 150 else { | 153 else { |
| 151 ASSERT(isExecutingScript()); | 154 ASSERT(isExecutingScript()); |
| 152 scriptLoader->executeScript(sourceCode); | 155 scriptLoader->executeScript(sourceCode, &compilationFinishTime); |
| 153 element->dispatchEvent(createScriptLoadEvent()); | 156 element->dispatchEvent(createScriptLoadEvent()); |
| 154 } | 157 } |
| 155 } | 158 } |
| 156 if (sourceCode.resource()) { | 159 // The exact value doesn't matter; valid time stamps are much bigger than th
is value. |
| 157 double timeBetweenLoadedAndCompiledMs = (WTF::monotonicallyIncreasingTim
e() - sourceCode.resource()->loadFinishTime()) * 1000; | 160 const double epsilon = 1; |
| 158 const char* histogramName = pendingScriptType == PendingScriptBlockingPa
rser ? "WebCore.Scripts.ParsingBlocking.TimeBetweenLoadedAndCompiled" : "WebCore
.Scripts.Deferred.TimeBetweenLoadedAndCompiled"; | 161 if (pendingScriptType == PendingScriptBlockingParser && !m_parserBlockingScr
iptAlreadyLoaded && compilationFinishTime > epsilon && loadFinishTime > epsilon)
{ |
| 159 blink::Platform::current()->histogramCustomCounts(histogramName, timeBet
weenLoadedAndCompiledMs, 0, 10000, 50); | 162 blink::Platform::current()->histogramCustomCounts("WebCore.Scripts.Parsi
ngBlocking.TimeBetweenLoadedAndCompiled", (compilationFinishTime - loadFinishTim
e) * 1000, 0, 10000, 50); |
| 160 } | 163 } |
| 161 | 164 |
| 162 ASSERT(!isExecutingScript()); | 165 ASSERT(!isExecutingScript()); |
| 163 } | 166 } |
| 164 | 167 |
| 165 void HTMLScriptRunner::notifyFinished(Resource* cachedResource) | 168 void HTMLScriptRunner::notifyFinished(Resource* cachedResource) |
| 166 { | 169 { |
| 167 m_host->notifyScriptLoaded(cachedResource); | 170 m_host->notifyScriptLoaded(cachedResource); |
| 168 } | 171 } |
| 169 | 172 |
| (...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 240 return true; | 243 return true; |
| 241 } | 244 } |
| 242 | 245 |
| 243 void HTMLScriptRunner::requestParsingBlockingScript(Element* element) | 246 void HTMLScriptRunner::requestParsingBlockingScript(Element* element) |
| 244 { | 247 { |
| 245 if (!requestPendingScript(m_parserBlockingScript, element)) | 248 if (!requestPendingScript(m_parserBlockingScript, element)) |
| 246 return; | 249 return; |
| 247 | 250 |
| 248 ASSERT(m_parserBlockingScript.resource()); | 251 ASSERT(m_parserBlockingScript.resource()); |
| 249 | 252 |
| 250 blink::Platform::current()->histogramEnumeration("WebCore.Scripts.ParsingBlo
cking.AlreadyLoaded", m_parserBlockingScript.resource()->isLoaded() ? 1 : 0, 2); | 253 m_parserBlockingScriptAlreadyLoaded = m_parserBlockingScript.resource()->isL
oaded(); |
| 254 blink::Platform::current()->histogramEnumeration("WebCore.Scripts.ParsingBlo
cking.AlreadyLoaded", m_parserBlockingScriptAlreadyLoaded ? 1 : 0, 2); |
| 251 // We only care about a load callback if resource is not already | 255 // We only care about a load callback if resource is not already |
| 252 // in the cache. Callers will attempt to run the m_parserBlockingScript | 256 // in the cache. Callers will attempt to run the m_parserBlockingScript |
| 253 // if possible before returning control to the parser. | 257 // if possible before returning control to the parser. |
| 254 if (!m_parserBlockingScript.resource()->isLoaded()) | 258 if (!m_parserBlockingScriptAlreadyLoaded) |
| 255 m_parserBlockingScript.watchForLoad(this); | 259 m_parserBlockingScript.watchForLoad(this); |
| 256 } | 260 } |
| 257 | 261 |
| 258 void HTMLScriptRunner::requestDeferredScript(Element* element) | 262 void HTMLScriptRunner::requestDeferredScript(Element* element) |
| 259 { | 263 { |
| 260 PendingScript pendingScript; | 264 PendingScript pendingScript; |
| 261 if (!requestPendingScript(pendingScript, element)) | 265 if (!requestPendingScript(pendingScript, element)) |
| 262 return; | 266 return; |
| 263 | 267 |
| 264 ASSERT(pendingScript.resource()); | 268 ASSERT(pendingScript.resource()); |
| (...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 327 | 331 |
| 328 void HTMLScriptRunner::trace(Visitor* visitor) | 332 void HTMLScriptRunner::trace(Visitor* visitor) |
| 329 { | 333 { |
| 330 visitor->trace(m_document); | 334 visitor->trace(m_document); |
| 331 visitor->trace(m_host); | 335 visitor->trace(m_host); |
| 332 visitor->trace(m_parserBlockingScript); | 336 visitor->trace(m_parserBlockingScript); |
| 333 visitor->trace(m_scriptsToExecuteAfterParsing); | 337 visitor->trace(m_scriptsToExecuteAfterParsing); |
| 334 } | 338 } |
| 335 | 339 |
| 336 } | 340 } |
| OLD | NEW |