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

Side by Side Diff: third_party/WebKit/Source/core/fetch/ResourceFetcher.cpp

Issue 1849223002: Blocking synchronous and third party doc.written scripts (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Resolved conflicts with latest 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 unified diff | Download patch
OLDNEW
1 /* 1 /*
2 Copyright (C) 1998 Lars Knoll (knoll@mpi-hd.mpg.de) 2 Copyright (C) 1998 Lars Knoll (knoll@mpi-hd.mpg.de)
3 Copyright (C) 2001 Dirk Mueller (mueller@kde.org) 3 Copyright (C) 2001 Dirk Mueller (mueller@kde.org)
4 Copyright (C) 2002 Waldo Bastian (bastian@kde.org) 4 Copyright (C) 2002 Waldo Bastian (bastian@kde.org)
5 Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011 Apple Inc. All rights reserved. 5 Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011 Apple Inc. All rights reserved.
6 Copyright (C) 2009 Torch Mobile Inc. http://www.torchmobile.com/ 6 Copyright (C) 2009 Torch Mobile Inc. http://www.torchmobile.com/
7 7
8 This library is free software; you can redistribute it and/or 8 This library is free software; you can redistribute it and/or
9 modify it under the terms of the GNU Library General Public 9 modify it under the terms of the GNU Library General Public
10 License as published by the Free Software Foundation; either 10 License as published by the Free Software Foundation; either
(...skipping 428 matching lines...) Expand 10 before | Expand all | Expand 10 after
439 if (!resource) 439 if (!resource)
440 resource = memoryCache()->resourceForURL(url, getCacheIdentifier()); 440 resource = memoryCache()->resourceForURL(url, getCacheIdentifier());
441 441
442 // See if we can use an existing resource from the cache. If so, we need to move it to be load blocking. 442 // See if we can use an existing resource from the cache. If so, we need to move it to be load blocking.
443 moveCachedNonBlockingResourceToBlocking(resource, request); 443 moveCachedNonBlockingResourceToBlocking(resource, request);
444 444
445 const RevalidationPolicy policy = determineRevalidationPolicy(factory.type() , request, resource, isStaticData); 445 const RevalidationPolicy policy = determineRevalidationPolicy(factory.type() , request, resource, isStaticData);
446 446
447 updateMemoryCacheStats(resource, policy, request, factory, isStaticData); 447 updateMemoryCacheStats(resource, policy, request, factory, isStaticData);
448 448
449 initializeResourceRequest(request.mutableResourceRequest(), factory.type()); 449 initializeResourceRequest(request.mutableResourceRequest(), factory.type(), request.defer());
450 switch (policy) { 450 switch (policy) {
451 case Reload: 451 case Reload:
452 memoryCache()->remove(resource); 452 memoryCache()->remove(resource);
453 // Fall through 453 // Fall through
454 case Load: 454 case Load:
455 resource = createResourceForLoading(request, request.charset(), factory) ; 455 resource = createResourceForLoading(request, request.charset(), factory) ;
456 break; 456 break;
457 case Revalidate: 457 case Revalidate:
458 initializeRevalidation(request, resource); 458 initializeRevalidation(request, resource);
459 break; 459 break;
(...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after
518 { 518 {
519 WebURLRequest::RequestContext requestContext = requestContextFromType(isMain Frame, type); 519 WebURLRequest::RequestContext requestContext = requestContextFromType(isMain Frame, type);
520 request.setRequestContext(requestContext); 520 request.setRequestContext(requestContext);
521 } 521 }
522 522
523 void ResourceFetcher::determineRequestContext(ResourceRequest& request, Resource ::Type type) 523 void ResourceFetcher::determineRequestContext(ResourceRequest& request, Resource ::Type type)
524 { 524 {
525 determineRequestContext(request, type, context().isMainFrame()); 525 determineRequestContext(request, type, context().isMainFrame());
526 } 526 }
527 527
528 void ResourceFetcher::initializeResourceRequest(ResourceRequest& request, Resour ce::Type type) 528 void ResourceFetcher::initializeResourceRequest(ResourceRequest& request, Resour ce::Type type, FetchRequest::DeferOption defer)
529 { 529 {
530 if (request.getCachePolicy() == WebCachePolicy::UseProtocolCachePolicy) 530 if (request.getCachePolicy() == WebCachePolicy::UseProtocolCachePolicy)
531 request.setCachePolicy(context().resourceRequestCachePolicy(request, typ e)); 531 request.setCachePolicy(context().resourceRequestCachePolicy(request, typ e, defer));
532 if (request.requestContext() == WebURLRequest::RequestContextUnspecified) 532 if (request.requestContext() == WebURLRequest::RequestContextUnspecified)
533 determineRequestContext(request, type); 533 determineRequestContext(request, type);
534 if (type == Resource::LinkPrefetch) 534 if (type == Resource::LinkPrefetch)
535 request.setHTTPHeaderField(HTTPNames::Purpose, "prefetch"); 535 request.setHTTPHeaderField(HTTPNames::Purpose, "prefetch");
536 536
537 context().addAdditionalRequestHeaders(request, (type == Resource::MainResour ce) ? FetchMainResource : FetchSubresource); 537 context().addAdditionalRequestHeaders(request, (type == Resource::MainResour ce) ? FetchMainResource : FetchSubresource);
538 } 538 }
539 539
540 void ResourceFetcher::initializeRevalidation(const FetchRequest& request, Resour ce* resource) 540 void ResourceFetcher::initializeRevalidation(const FetchRequest& request, Resour ce* resource)
541 { 541 {
542 ASSERT(resource); 542 ASSERT(resource);
543 ASSERT(memoryCache()->contains(resource)); 543 ASSERT(memoryCache()->contains(resource));
544 ASSERT(resource->isLoaded()); 544 ASSERT(resource->isLoaded());
545 ASSERT(resource->canUseCacheValidator()); 545 ASSERT(resource->canUseCacheValidator());
546 ASSERT(!resource->isCacheValidator()); 546 ASSERT(!resource->isCacheValidator());
547 ASSERT(!context().isControlledByServiceWorker()); 547 ASSERT(!context().isControlledByServiceWorker());
548 548
549 ResourceRequest revalidatingRequest(resource->resourceRequest()); 549 ResourceRequest revalidatingRequest(resource->resourceRequest());
550 revalidatingRequest.clearHTTPReferrer(); 550 revalidatingRequest.clearHTTPReferrer();
551 initializeResourceRequest(revalidatingRequest, resource->getType()); 551 initializeResourceRequest(revalidatingRequest, resource->getType(), request. defer());
552 552
553 const AtomicString& lastModified = resource->response().httpHeaderField(HTTP Names::Last_Modified); 553 const AtomicString& lastModified = resource->response().httpHeaderField(HTTP Names::Last_Modified);
554 const AtomicString& eTag = resource->response().httpHeaderField(HTTPNames::E Tag); 554 const AtomicString& eTag = resource->response().httpHeaderField(HTTPNames::E Tag);
555 if (!lastModified.isEmpty() || !eTag.isEmpty()) { 555 if (!lastModified.isEmpty() || !eTag.isEmpty()) {
556 ASSERT(context().getCachePolicy() != CachePolicyReload); 556 ASSERT(context().getCachePolicy() != CachePolicyReload);
557 if (context().getCachePolicy() == CachePolicyRevalidate) 557 if (context().getCachePolicy() == CachePolicyRevalidate)
558 revalidatingRequest.setHTTPHeaderField(HTTPNames::Cache_Control, "ma x-age=0"); 558 revalidatingRequest.setHTTPHeaderField(HTTPNames::Cache_Control, "ma x-age=0");
559 } 559 }
560 if (!lastModified.isEmpty()) 560 if (!lastModified.isEmpty())
561 revalidatingRequest.setHTTPHeaderField(HTTPNames::If_Modified_Since, las tModified); 561 revalidatingRequest.setHTTPHeaderField(HTTPNames::If_Modified_Since, las tModified);
(...skipping 624 matching lines...) Expand 10 before | Expand all | Expand 10 after
1186 visitor->trace(m_context); 1186 visitor->trace(m_context);
1187 visitor->trace(m_archive); 1187 visitor->trace(m_archive);
1188 visitor->trace(m_loaders); 1188 visitor->trace(m_loaders);
1189 visitor->trace(m_nonBlockingLoaders); 1189 visitor->trace(m_nonBlockingLoaders);
1190 visitor->trace(m_documentResources); 1190 visitor->trace(m_documentResources);
1191 visitor->trace(m_preloads); 1191 visitor->trace(m_preloads);
1192 visitor->trace(m_resourceTimingInfoMap); 1192 visitor->trace(m_resourceTimingInfoMap);
1193 } 1193 }
1194 1194
1195 } // namespace blink 1195 } // namespace blink
OLDNEW
« no previous file with comments | « third_party/WebKit/Source/core/fetch/ResourceFetcher.h ('k') | third_party/WebKit/Source/core/loader/FrameFetchContext.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698