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

Unified Diff: third_party/WebKit/Source/core/html/parser/HTMLResourcePreloader.cpp

Issue 1819593002: Preload scan external css for @import (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Add histogram to histograms.xml (trybots previous) Created 4 years, 8 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
Index: third_party/WebKit/Source/core/html/parser/HTMLResourcePreloader.cpp
diff --git a/third_party/WebKit/Source/core/html/parser/HTMLResourcePreloader.cpp b/third_party/WebKit/Source/core/html/parser/HTMLResourcePreloader.cpp
index e29b24e804a733d7b7c9ad0988b400cea1eb9193..88bf5409336fef8be9b651a9d47d7c5d63322a54 100644
--- a/third_party/WebKit/Source/core/html/parser/HTMLResourcePreloader.cpp
+++ b/third_party/WebKit/Source/core/html/parser/HTMLResourcePreloader.cpp
@@ -26,6 +26,7 @@
#include "core/html/parser/HTMLResourcePreloader.h"
#include "core/dom/Document.h"
+#include "core/fetch/CSSStyleSheetResource.h"
#include "core/fetch/FetchInitiatorInfo.h"
#include "core/fetch/ResourceFetcher.h"
#include "core/loader/DocumentLoader.h"
@@ -48,6 +49,13 @@ DEFINE_TRACE(HTMLResourcePreloader)
visitor->trace(m_document);
}
+int HTMLResourcePreloader::countPreloads()
+{
+ if (m_document->loader())
+ return m_document->loader()->fetcher()->countPreloads();
+ return 0;
+}
+
static void preconnectHost(PreloadRequest* request, const NetworkHintsInterface& networkHintsInterface)
{
ASSERT(request);
@@ -75,7 +83,12 @@ void HTMLResourcePreloader::preload(PassOwnPtr<PreloadRequest> preload, const Ne
if (preload->resourceType() == Resource::Script || preload->resourceType() == Resource::CSSStyleSheet || preload->resourceType() == Resource::ImportResource)
request.setCharset(preload->charset().isEmpty() ? m_document->characterSet().getString() : preload->charset());
request.setForPreload(true);
- m_document->loader()->startPreload(preload->resourceType(), request);
+ Resource* resource = m_document->loader()->startPreload(preload->resourceType(), request);
+ if (resource && preload->resourceType() == Resource::CSSStyleSheet && RuntimeEnabledFeatures::cssPreloadImportEnabled()) {
+ OwnPtr<CSSPreloaderResourceClient> client = adoptPtr(new CSSPreloaderResourceClient(resource, this));
+ resource->addClient(client.get());
+ m_cssPreloaders.add(client.release());
+ }
}
} // namespace blink

Powered by Google App Engine
This is Rietveld 408576698