Index: chrome/browser/net/predictor.h |
=================================================================== |
--- chrome/browser/net/predictor.h (revision 54027) |
+++ chrome/browser/net/predictor.h (working copy) |
@@ -13,8 +13,8 @@ |
// Subresource relationships are usually acquired from the referrer field in a |
// navigation. A subresource URL may be associated with a referrer URL. Later |
// navigations may, if the likelihood of needing the subresource is high enough, |
-// cause this module to speculatively create a TCP/IP connection that will |
-// probably be needed to fetch the subresource. |
+// cause this module to speculatively create a TCP/IP connection. If there is |
+// only a low likelihood, then a DNS pre-resolution operation may be performed. |
#ifndef CHROME_BROWSER_NET_PREDICTOR_H_ |
#define CHROME_BROWSER_NET_PREDICTOR_H_ |
@@ -49,9 +49,19 @@ |
public: |
// A version number for prefs that are saved. This should be incremented when |
// we change the format so that we discard old data. |
- enum { DNS_REFERRER_VERSION = 1 }; |
+ enum { PREDICTOR_REFERRER_VERSION = 2 }; |
-// |max_concurrent| specifies how many concurrent (parallel) prefetches will |
+ // Depending on the expected_subresource_use_, we may either make a TCP/IP |
+ // preconnection, or merely pre-resolve the hostname via DNS (or even do |
+ // nothing). The following are the threasholds for taking those actions. |
+ static const double kPreconnectWorthyExpectedValue; |
+ static const double kDNSPreresolutionWorthyExpectedValue; |
+ // Values of expected_subresource_use_ that are less than the following |
+ // threshold will be discarded when we Trim() the values, such as is done when |
+ // the process ends, and some values are persisted. |
+ static const double kPersistWorthyExpectedValue; |
+ |
+ // |max_concurrent| specifies how many concurrent (parallel) prefetches will |
// be performed. Host lookups will be issued through |host_resolver|. |
Predictor(net::HostResolver* host_resolver, |
base::TimeDelta max_queue_delay_ms, size_t max_concurrent, |
@@ -73,14 +83,6 @@ |
void Resolve(const GURL& url, |
UrlInfo::ResolutionMotivation motivation); |
- // Get latency benefit of the prefetch that we are navigating to. |
- bool AccruePrefetchBenefits(const GURL& referrer, |
- UrlInfo* navigation_info); |
- |
- // Instigate preresolution of any domains we predict will be needed after this |
- // navigation. |
- void PredictSubresources(const GURL& url); |
- |
// Instigate pre-connection to any URLs we predict will be needed after this |
// navigation (typically more-embedded resources on a page). |
void PredictFrameSubresources(const GURL& url); |
@@ -240,12 +242,6 @@ |
// When true, we don't make new lookup requests. |
bool shutdown_; |
- // A list of successful events resulting from pre-fetching. |
- UrlInfo::DnsInfoTable dns_cache_hits_; |
- // A map of hosts that were evicted from our cache (after we prefetched them) |
- // and before the HTTP stack tried to look them up. |
- Results cache_eviction_map_; |
- |
// The number of concurrent lookups currently allowed. |
const size_t max_concurrent_dns_lookups_; |