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

Unified Diff: net/http/http_cache.cc

Issue 19747: URLRequestContext and disk cache for media files (Closed)
Patch Set: signed and unsigned... Created 11 years, 10 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
« no previous file with comments | « net/http/http_cache.h ('k') | net/http/http_cache_unittest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: net/http/http_cache.cc
diff --git a/net/http/http_cache.cc b/net/http/http_cache.cc
index c54b6d4652fe44ff13db5e3a40ab781782294034..913dc009fde26f2bc7815b694e002475f4567527 100644
--- a/net/http/http_cache.cc
+++ b/net/http/http_cache.cc
@@ -286,6 +286,9 @@ class HttpCache::Transaction
// Called to write response_ to the cache entry.
void WriteResponseInfoToEntry();
+ // Called to truncate response content in the entry.
+ void TruncateResponseData();
+
// Called to append response data to the cache entry.
void AppendResponseDataToEntry(IOBuffer* data, int data_len);
@@ -790,6 +793,12 @@ int HttpCache::Transaction::ReadResponseInfoFromEntry() {
if (!HttpCache::ReadResponseInfo(entry_->disk_entry, &response_))
return ERR_FAILED;
+ // If the cache object is used for media file, we want the file handle of
+ // response data.
+ if (cache_->type() == HttpCache::MEDIA)
+ response_.response_data_file =
+ entry_->disk_entry->GetPlatformFile(kResponseContentIndex);
+
return OK;
}
@@ -846,6 +855,27 @@ void HttpCache::Transaction::AppendResponseDataToEntry(IOBuffer* data,
WriteToEntry(kResponseContentIndex, current_size, data, data_len);
}
+void HttpCache::Transaction::TruncateResponseData() {
+ if (!entry_)
+ return;
+
+ // If the cache is for media files, we try to prepare the response data
+ // file as an external file and truncate it afterwards.
+ // Recipient of ResponseInfo should judge from |response_.response_data_file|
+ // to tell whether an external file of response data is available for reading
+ // or not.
+ // TODO(hclam): we should prepare the target stream as extern file only
+ // if we get a valid response from server, i.e. 200. We don't want empty
+ // cache files for redirection or external files for erroneous requests.
+ response_.response_data_file = base::kInvalidPlatformFileValue;
+ if (cache_->type() == HttpCache::MEDIA)
+ response_.response_data_file =
+ entry_->disk_entry->UseExternalFile(kResponseContentIndex);
+
+ // Truncate the stream.
+ WriteToEntry(kResponseContentIndex, 0, NULL, 0);
+}
+
void HttpCache::Transaction::DoneWritingToEntry(bool success) {
if (!entry_)
return;
@@ -902,8 +932,8 @@ void HttpCache::Transaction::OnNetworkInfoAvailable(int result) {
response_ = *new_response;
WriteResponseInfoToEntry();
- // Truncate the response data
- WriteToEntry(kResponseContentIndex, 0, NULL, 0);
+ // Truncate response data
+ TruncateResponseData();
// If this response is a redirect, then we can stop writing now. (We
// don't need to cache the response body of a redirect.)
@@ -958,14 +988,28 @@ HttpCache::HttpCache(ProxyService* proxy_service,
int cache_size)
: disk_cache_dir_(cache_dir),
mode_(NORMAL),
+ type_(COMMON),
network_layer_(HttpNetworkLayer::CreateFactory(proxy_service)),
ALLOW_THIS_IN_INITIALIZER_LIST(task_factory_(this)),
in_memory_cache_(false),
cache_size_(cache_size) {
}
+HttpCache::HttpCache(HttpNetworkSession* session,
+ const std::wstring& cache_dir,
+ int cache_size)
+ : disk_cache_dir_(cache_dir),
+ mode_(NORMAL),
+ type_(COMMON),
+ network_layer_(HttpNetworkLayer::CreateFactory(session)),
+ ALLOW_THIS_IN_INITIALIZER_LIST(task_factory_(this)),
+ in_memory_cache_(false),
+ cache_size_(cache_size) {
+}
+
HttpCache::HttpCache(ProxyService* proxy_service, int cache_size)
: mode_(NORMAL),
+ type_(COMMON),
network_layer_(HttpNetworkLayer::CreateFactory(proxy_service)),
ALLOW_THIS_IN_INITIALIZER_LIST(task_factory_(this)),
in_memory_cache_(true),
@@ -975,6 +1019,7 @@ HttpCache::HttpCache(ProxyService* proxy_service, int cache_size)
HttpCache::HttpCache(HttpTransactionFactory* network_layer,
disk_cache::Backend* disk_cache)
: mode_(NORMAL),
+ type_(COMMON),
network_layer_(network_layer),
disk_cache_(disk_cache),
ALLOW_THIS_IN_INITIALIZER_LIST(task_factory_(this)),
« no previous file with comments | « net/http/http_cache.h ('k') | net/http/http_cache_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698