OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 // Support modularity by calling to load a new SDCH filter dictionary. | 5 // Support modularity by calling to load a new SDCH filter dictionary. |
6 // Note that this sort of calling can't be done in the /net directory, as it has | 6 // Note that this sort of calling can't be done in the /net directory, as it has |
7 // no concept of the HTTP cache (which is only visible at the browser level). | 7 // no concept of the HTTP cache (which is only visible at the browser level). |
8 | 8 |
9 #ifndef CHROME_BROWSER_NET_SDCH_DICTIONARY_FETCHER_H_ | 9 #ifndef CHROME_BROWSER_NET_SDCH_DICTIONARY_FETCHER_H_ |
10 #define CHROME_BROWSER_NET_SDCH_DICTIONARY_FETCHER_H_ | 10 #define CHROME_BROWSER_NET_SDCH_DICTIONARY_FETCHER_H_ |
(...skipping 19 matching lines...) Expand all Loading... |
30 public base::NonThreadSafe { | 30 public base::NonThreadSafe { |
31 public: | 31 public: |
32 // Consumer must guarantee that the SdchManager pointer outlives | 32 // Consumer must guarantee that the SdchManager pointer outlives |
33 // this object. The current implementation guarantees this by | 33 // this object. The current implementation guarantees this by |
34 // the SdchManager owning this object. | 34 // the SdchManager owning this object. |
35 SdchDictionaryFetcher(net::SdchManager* manager, | 35 SdchDictionaryFetcher(net::SdchManager* manager, |
36 net::URLRequestContextGetter* context); | 36 net::URLRequestContextGetter* context); |
37 virtual ~SdchDictionaryFetcher(); | 37 virtual ~SdchDictionaryFetcher(); |
38 | 38 |
39 // Implementation of SdchFetcher class. | 39 // Implementation of SdchFetcher class. |
40 // This method gets the requested dictionary, and then calls back into the | |
41 // SdchManager class with the dictionary's text. | |
42 virtual void Schedule(const GURL& dictionary_url) OVERRIDE; | 40 virtual void Schedule(const GURL& dictionary_url) OVERRIDE; |
| 41 virtual void Cancel() OVERRIDE; |
43 | 42 |
44 private: | 43 private: |
45 // Delay in ms between Schedule and actual download. | 44 // Delay in ms between Schedule and actual download. |
46 // This leaves the URL in a queue, which is de-duped, so that there is less | 45 // This leaves the URL in a queue, which is de-duped, so that there is less |
47 // chance we'll try to load the same URL multiple times when a pile of | 46 // chance we'll try to load the same URL multiple times when a pile of |
48 // page subresources (or tabs opened in parallel) all suggest the dictionary. | 47 // page subresources (or tabs opened in parallel) all suggest the dictionary. |
49 static const int kMsDelayFromRequestTillDownload = 100; | 48 static const int kMsDelayFromRequestTillDownload = 100; |
50 | 49 |
51 // Ensure the download after the above delay. | 50 // Ensure the download after the above delay. |
52 void ScheduleDelayedRun(); | 51 void ScheduleDelayedRun(); |
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
89 std::set<GURL> attempted_load_; | 88 std::set<GURL> attempted_load_; |
90 | 89 |
91 // Store the system_url_request_context_getter to use it when we start | 90 // Store the system_url_request_context_getter to use it when we start |
92 // fetching. | 91 // fetching. |
93 scoped_refptr<net::URLRequestContextGetter> context_; | 92 scoped_refptr<net::URLRequestContextGetter> context_; |
94 | 93 |
95 DISALLOW_COPY_AND_ASSIGN(SdchDictionaryFetcher); | 94 DISALLOW_COPY_AND_ASSIGN(SdchDictionaryFetcher); |
96 }; | 95 }; |
97 | 96 |
98 #endif // CHROME_BROWSER_NET_SDCH_DICTIONARY_FETCHER_H_ | 97 #endif // CHROME_BROWSER_NET_SDCH_DICTIONARY_FETCHER_H_ |
OLD | NEW |