| OLD | NEW | 
|---|
| 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 | 5     Copyright (C) 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011 Apple Inc. All | 
| 6     rights reserved. | 6     rights reserved. | 
| 7     Copyright (C) 2009 Torch Mobile Inc. http://www.torchmobile.com/ | 7     Copyright (C) 2009 Torch Mobile Inc. http://www.torchmobile.com/ | 
| 8 | 8 | 
| 9     This library is free software; you can redistribute it and/or | 9     This library is free software; you can redistribute it and/or | 
| 10     modify it under the terms of the GNU Library General Public | 10     modify it under the terms of the GNU Library General Public | 
| (...skipping 586 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 597   bool is_static_data = is_data_url || substitute_data.IsValid() || archive_; | 597   bool is_static_data = is_data_url || substitute_data.IsValid() || archive_; | 
| 598   if (is_static_data) { | 598   if (is_static_data) { | 
| 599     resource = ResourceForStaticData(params, factory, substitute_data); | 599     resource = ResourceForStaticData(params, factory, substitute_data); | 
| 600     // Abort the request if the archive doesn't contain the resource, except in | 600     // Abort the request if the archive doesn't contain the resource, except in | 
| 601     // the case of data URLs which might have resources such as fonts that need | 601     // the case of data URLs which might have resources such as fonts that need | 
| 602     // to be decoded only on demand. These data URLs are allowed to be | 602     // to be decoded only on demand. These data URLs are allowed to be | 
| 603     // processed using the normal ResourceFetcher machinery. | 603     // processed using the normal ResourceFetcher machinery. | 
| 604     if (!resource && !is_data_url && archive_) | 604     if (!resource && !is_data_url && archive_) | 
| 605       return nullptr; | 605       return nullptr; | 
| 606   } | 606   } | 
| 607   if (!resource) { | 607   if (!resource && IsMainThread()) { | 
| 608     resource = | 608     resource = | 
| 609         GetMemoryCache()->ResourceForURL(params.Url(), GetCacheIdentifier()); | 609         GetMemoryCache()->ResourceForURL(params.Url(), GetCacheIdentifier()); | 
| 610   } | 610   } | 
| 611 | 611 | 
| 612   // If we got a preloaded resource from the cache for a non-preload request, | 612   // If we got a preloaded resource from the cache for a non-preload request, | 
| 613   // we may need to make it block the onload event. | 613   // we may need to make it block the onload event. | 
| 614   MakePreloadedResourceBlockOnloadIfNeeded(resource, params); | 614   MakePreloadedResourceBlockOnloadIfNeeded(resource, params); | 
| 615 | 615 | 
| 616   const RevalidationPolicy policy = DetermineRevalidationPolicy( | 616   const RevalidationPolicy policy = DetermineRevalidationPolicy( | 
| 617       factory.GetType(), params, resource, is_static_data); | 617       factory.GetType(), params, resource, is_static_data); | 
| (...skipping 126 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 744     revalidating_request.SetHTTPHeaderField(HTTPNames::If_None_Match, e_tag); | 744     revalidating_request.SetHTTPHeaderField(HTTPNames::If_None_Match, e_tag); | 
| 745 | 745 | 
| 746   resource->SetRevalidatingRequest(revalidating_request); | 746   resource->SetRevalidatingRequest(revalidating_request); | 
| 747 } | 747 } | 
| 748 | 748 | 
| 749 Resource* ResourceFetcher::CreateResourceForLoading( | 749 Resource* ResourceFetcher::CreateResourceForLoading( | 
| 750     FetchParameters& params, | 750     FetchParameters& params, | 
| 751     const String& charset, | 751     const String& charset, | 
| 752     const ResourceFactory& factory) { | 752     const ResourceFactory& factory) { | 
| 753   const String cache_identifier = GetCacheIdentifier(); | 753   const String cache_identifier = GetCacheIdentifier(); | 
| 754   DCHECK(!GetMemoryCache()->ResourceForURL(params.GetResourceRequest().Url(), | 754   DCHECK(!IsMainThread() || | 
|  | 755          !GetMemoryCache()->ResourceForURL(params.GetResourceRequest().Url(), | 
| 755                                            cache_identifier)); | 756                                            cache_identifier)); | 
| 756 | 757 | 
| 757   RESOURCE_LOADING_DVLOG(1) << "Loading Resource for " | 758   RESOURCE_LOADING_DVLOG(1) << "Loading Resource for " | 
| 758                             << params.GetResourceRequest().Url().ElidedString(); | 759                             << params.GetResourceRequest().Url().ElidedString(); | 
| 759 | 760 | 
| 760   Resource* resource = | 761   Resource* resource = | 
| 761       factory.Create(params.GetResourceRequest(), params.Options(), charset); | 762       factory.Create(params.GetResourceRequest(), params.Options(), charset); | 
| 762   resource->SetLinkPreload(params.IsLinkPreload()); | 763   resource->SetLinkPreload(params.IsLinkPreload()); | 
| 763   if (params.IsSpeculativePreload()) { | 764   if (params.IsSpeculativePreload()) { | 
| 764     resource->SetPreloadDiscoveryTime(params.PreloadDiscoveryTime()); | 765     resource->SetPreloadDiscoveryTime(params.PreloadDiscoveryTime()); | 
| 765   } | 766   } | 
| 766   resource->SetCacheIdentifier(cache_identifier); | 767   resource->SetCacheIdentifier(cache_identifier); | 
| 767 | 768 | 
| 768   // - Don't add main resource to cache to prevent reuse. | 769   // - Don't add main resource to cache to prevent reuse. | 
| 769   // - Don't add the resource if its body will not be stored. | 770   // - Don't add the resource if its body will not be stored. | 
| 770   if (factory.GetType() != Resource::kMainResource && | 771   if (IsMainThread() && factory.GetType() != Resource::kMainResource && | 
| 771       params.Options().data_buffering_policy != kDoNotBufferData) { | 772       params.Options().data_buffering_policy != kDoNotBufferData) { | 
| 772     GetMemoryCache()->Add(resource); | 773     GetMemoryCache()->Add(resource); | 
| 773   } | 774   } | 
| 774   return resource; | 775   return resource; | 
| 775 } | 776 } | 
| 776 | 777 | 
| 777 void ResourceFetcher::StorePerformanceTimingInitiatorInformation( | 778 void ResourceFetcher::StorePerformanceTimingInitiatorInformation( | 
| 778     Resource* resource) { | 779     Resource* resource) { | 
| 779   const AtomicString& fetch_initiator = resource->Options().initiator_info.name; | 780   const AtomicString& fetch_initiator = resource->Options().initiator_info.name; | 
| 780   if (fetch_initiator == FetchInitiatorTypeNames::internal) | 781   if (fetch_initiator == FetchInitiatorTypeNames::internal) | 
| (...skipping 488 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 1269   ResourceRequest request(resource->GetResourceRequest()); | 1270   ResourceRequest request(resource->GetResourceRequest()); | 
| 1270   ResourceLoader* loader = nullptr; | 1271   ResourceLoader* loader = nullptr; | 
| 1271 | 1272 | 
| 1272   { | 1273   { | 
| 1273     // Forbids JavaScript/addClient/removeClient/revalidation until start() | 1274     // Forbids JavaScript/addClient/removeClient/revalidation until start() | 
| 1274     // to prevent unintended state transitions. | 1275     // to prevent unintended state transitions. | 
| 1275     Resource::ProhibitAddRemoveClientInScope | 1276     Resource::ProhibitAddRemoveClientInScope | 
| 1276         prohibit_add_remove_client_in_scope(resource); | 1277         prohibit_add_remove_client_in_scope(resource); | 
| 1277     Resource::RevalidationStartForbiddenScope | 1278     Resource::RevalidationStartForbiddenScope | 
| 1278         revalidation_start_forbidden_scope(resource); | 1279         revalidation_start_forbidden_scope(resource); | 
| 1279     ScriptForbiddenScope script_forbidden_scope; | 1280     ScriptForbiddenIfMainThreadScope script_forbidden_scope; | 
| 1280 | 1281 | 
| 1281     if (!Context().ShouldLoadNewResource(resource->GetType())) { | 1282     if (!Context().ShouldLoadNewResource(resource->GetType()) && | 
|  | 1283         IsMainThread()) { | 
| 1282       GetMemoryCache()->Remove(resource); | 1284       GetMemoryCache()->Remove(resource); | 
| 1283       return false; | 1285       return false; | 
| 1284     } | 1286     } | 
| 1285 | 1287 | 
| 1286     ResourceResponse response; | 1288     ResourceResponse response; | 
| 1287 | 1289 | 
| 1288     blink::probe::PlatformSendRequest probe(&Context(), resource->Identifier(), | 1290     blink::probe::PlatformSendRequest probe(&Context(), resource->Identifier(), | 
| 1289                                             request, response, | 1291                                             request, response, | 
| 1290                                             resource->Options().initiator_info); | 1292                                             resource->Options().initiator_info); | 
| 1291 | 1293 | 
| (...skipping 266 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 1558   visitor->Trace(context_); | 1560   visitor->Trace(context_); | 
| 1559   visitor->Trace(archive_); | 1561   visitor->Trace(archive_); | 
| 1560   visitor->Trace(loaders_); | 1562   visitor->Trace(loaders_); | 
| 1561   visitor->Trace(non_blocking_loaders_); | 1563   visitor->Trace(non_blocking_loaders_); | 
| 1562   visitor->Trace(document_resources_); | 1564   visitor->Trace(document_resources_); | 
| 1563   visitor->Trace(preloads_); | 1565   visitor->Trace(preloads_); | 
| 1564   visitor->Trace(resource_timing_info_map_); | 1566   visitor->Trace(resource_timing_info_map_); | 
| 1565 } | 1567 } | 
| 1566 | 1568 | 
| 1567 }  // namespace blink | 1569 }  // namespace blink | 
| OLD | NEW | 
|---|