summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authoreroman@chromium.org <eroman@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-09-22 00:04:29 +0000
committereroman@chromium.org <eroman@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-09-22 00:04:29 +0000
commite8c927ab11958c3d1d7c768674795bcbc8b67bbb (patch)
treedb4e04e6398a31e4129ea6abfe8bbeab4a4be174
parent7f6135589837c30d13e0d60480f44df33db2fec2 (diff)
downloadchromium_src-e8c927ab11958c3d1d7c768674795bcbc8b67bbb.zip
chromium_src-e8c927ab11958c3d1d7c768674795bcbc8b67bbb.tar.gz
chromium_src-e8c927ab11958c3d1d7c768674795bcbc8b67bbb.tar.bz2
Revert 25873.
This appears to be responsible for a regression in downloading of files. BUG=http://crbug.com/406 TBR=darin Review URL: http://codereview.chromium.org/215035 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@26764 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--net/http/http_cache.cc104
-rw-r--r--net/http/http_cache_unittest.cc19
-rw-r--r--net/http/http_transaction_unittest.h1
3 files changed, 35 insertions, 89 deletions
diff --git a/net/http/http_cache.cc b/net/http/http_cache.cc
index d6cbf45..9cb9786 100644
--- a/net/http/http_cache.cc
+++ b/net/http/http_cache.cc
@@ -192,10 +192,7 @@ class HttpCache::Transaction
network_read_callback_(this, &Transaction::OnNetworkReadCompleted)),
ALLOW_THIS_IN_INITIALIZER_LIST(
cache_read_callback_(new CancelableCompletionCallback<Transaction>(
- this, &Transaction::OnCacheReadCompleted))),
- ALLOW_THIS_IN_INITIALIZER_LIST(
- cache_write_callback_(new CancelableCompletionCallback<Transaction>(
- this, &Transaction::OnCacheWriteCompleted))) {
+ this, &Transaction::OnCacheReadCompleted))) {
}
// Clean up the transaction.
@@ -336,18 +333,15 @@ class HttpCache::Transaction
// Called to write data to the cache entry. If the write fails, then the
// cache entry is destroyed. Future calls to this function will just do
- // nothing without side-effect. Returns a network error code.
- int WriteToEntry(int index, int offset, IOBuffer* data, int data_len,
- CompletionCallback* callback);
+ // nothing without side-effect.
+ void WriteToEntry(int index, int offset, IOBuffer* data, int data_len);
// Called to write response_ to the cache entry. |truncated| indicates if the
// entry should be marked as incomplete.
void WriteResponseInfoToEntry(bool truncated);
- // Called to append response data to the cache entry. Returns a network error
- // code.
- int AppendResponseDataToEntry(IOBuffer* data, int data_len,
- CompletionCallback* callback);
+ // Called to append response data to the cache entry.
+ void AppendResponseDataToEntry(IOBuffer* data, int data_len);
// Called to truncate response content in the entry.
void TruncateResponseData();
@@ -373,9 +367,6 @@ class HttpCache::Transaction
// working with range requests.
int DoPartialCacheReadCompleted(int result);
- // Performs the needed work after writing data to the cache.
- int DoCacheWriteCompleted(int result);
-
// Called to signal completion of the network transaction's Start method:
void OnNetworkInfoAvailable(int result);
@@ -385,9 +376,6 @@ class HttpCache::Transaction
// Called to signal completion of the cache's ReadData method:
void OnCacheReadCompleted(int result);
- // Called to signal completion of the cache's WriteData method:
- void OnCacheWriteCompleted(int result);
-
scoped_refptr<LoadLog> load_log_;
const HttpRequestInfo* request_;
scoped_ptr<HttpRequestInfo> custom_request_;
@@ -416,8 +404,6 @@ class HttpCache::Transaction
CompletionCallbackImpl<Transaction> network_read_callback_;
scoped_refptr<CancelableCompletionCallback<Transaction> >
cache_read_callback_;
- scoped_refptr<CancelableCompletionCallback<Transaction> >
- cache_write_callback_;
};
HttpCache::Transaction::~Transaction() {
@@ -436,10 +422,9 @@ HttpCache::Transaction::~Transaction() {
// If there is an outstanding callback, mark it as cancelled so running it
// does nothing.
cache_read_callback_->Cancel();
- cache_write_callback_->Cancel();
- // We could still have a cache read or write in progress, so we just null the
- // cache_ pointer to signal that we are dead. See DoCacheReadCompleted.
+ // We could still have a cache read in progress, so we just null the cache_
+ // pointer to signal that we are dead. See OnCacheReadCompleted.
cache_ = NULL;
}
@@ -1287,7 +1272,7 @@ int HttpCache::Transaction::ReadFromNetwork(IOBuffer* data, int data_len) {
int HttpCache::Transaction::ReadFromEntry(IOBuffer* data, int data_len) {
DCHECK(entry_);
int rv;
- cache_read_callback_->AddRef(); // Balanced in OnCacheReadCompleted.
+ cache_read_callback_->AddRef(); // Balanced in DoCacheReadCompleted.
if (partial_.get()) {
rv = partial_->CacheRead(entry_->disk_entry, data, data_len,
cache_read_callback_);
@@ -1297,12 +1282,11 @@ int HttpCache::Transaction::ReadFromEntry(IOBuffer* data, int data_len) {
}
read_buf_ = data;
read_buf_len_ = data_len;
- if (rv != ERR_IO_PENDING)
- cache_read_callback_->Release();
-
- if (rv >= 0)
+ if (rv >= 0) {
rv = DoCacheReadCompleted(rv);
-
+ } else if (rv != ERR_IO_PENDING) {
+ cache_read_callback_->Release();
+ }
return rv;
}
@@ -1317,25 +1301,22 @@ int HttpCache::Transaction::ReadResponseInfoFromEntry() {
return read_ok ? OK : ERR_CACHE_READ_FAILURE;
}
-int HttpCache::Transaction::WriteToEntry(int index, int offset,
- IOBuffer* data, int data_len,
- CompletionCallback* callback) {
+void HttpCache::Transaction::WriteToEntry(int index, int offset,
+ IOBuffer* data, int data_len) {
if (!entry_)
- return data_len;
+ return;
int rv = 0;
if (!partial_.get() || !data_len) {
- rv = entry_->disk_entry->WriteData(index, offset, data, data_len, callback,
+ rv = entry_->disk_entry->WriteData(index, offset, data, data_len, NULL,
true);
} else {
- rv = partial_->CacheWrite(entry_->disk_entry, data, data_len, callback);
+ rv = partial_->CacheWrite(entry_->disk_entry, data, data_len, NULL);
}
-
- if (rv >= 0 && rv != data_len) {
+ if (rv != data_len) {
DLOG(ERROR) << "failed to write response data to cache";
DoneWritingToEntry(false);
}
- return rv;
}
void HttpCache::Transaction::WriteResponseInfoToEntry(bool truncated) {
@@ -1373,14 +1354,13 @@ void HttpCache::Transaction::WriteResponseInfoToEntry(bool truncated) {
}
}
-int HttpCache::Transaction::AppendResponseDataToEntry(
- IOBuffer* data, int data_len, CompletionCallback* callback) {
+void HttpCache::Transaction::AppendResponseDataToEntry(IOBuffer* data,
+ int data_len) {
if (!entry_ || !data_len)
- return data_len;
+ return;
int current_size = entry_->disk_entry->GetDataSize(kResponseContentIndex);
- return WriteToEntry(kResponseContentIndex, current_size, data, data_len,
- callback);
+ WriteToEntry(kResponseContentIndex, current_size, data, data_len);
}
void HttpCache::Transaction::TruncateResponseData() {
@@ -1388,8 +1368,7 @@ void HttpCache::Transaction::TruncateResponseData() {
return;
// Truncate the stream.
- int rv = WriteToEntry(kResponseContentIndex, 0, NULL, 0, NULL);
- DCHECK(rv != ERR_IO_PENDING);
+ WriteToEntry(kResponseContentIndex, 0, NULL, 0);
}
void HttpCache::Transaction::DoneWritingToEntry(bool success) {
@@ -1419,13 +1398,15 @@ int HttpCache::Transaction::DoNetworkReadCompleted(int result) {
if (revoked())
return HandleResult(ERR_UNEXPECTED);
- cache_write_callback_->AddRef(); // Balanced in DoCacheWriteCompleted.
+ AppendResponseDataToEntry(read_buf_, result);
+
+ if (partial_.get())
+ return DoPartialNetworkReadCompleted(result);
- result = AppendResponseDataToEntry(read_buf_, result, cache_write_callback_);
- if (result == ERR_IO_PENDING)
- return result;
+ if (result == 0) // End of file.
+ DoneWritingToEntry(true);
- return DoCacheWriteCompleted(result);
+ return HandleResult(result);
}
int HttpCache::Transaction::DoPartialNetworkReadCompleted(int result) {
@@ -1447,6 +1428,7 @@ int HttpCache::Transaction::DoPartialNetworkReadCompleted(int result) {
int HttpCache::Transaction::DoCacheReadCompleted(int result) {
DCHECK(cache_);
+ cache_read_callback_->Release(); // Balance the AddRef() from Start().
if (revoked())
return HandleResult(ERR_UNEXPECTED);
@@ -1481,25 +1463,6 @@ int HttpCache::Transaction::DoPartialCacheReadCompleted(int result) {
return HandleResult(result);
}
-int HttpCache::Transaction::DoCacheWriteCompleted(int result) {
- DCHECK(cache_);
- // Balance the AddRef from DoNetworkReadCompleted.
- cache_write_callback_->Release();
- if (revoked())
- return HandleResult(ERR_UNEXPECTED);
-
- if (result < 0)
- return HandleResult(result);
-
- if (partial_.get())
- return DoPartialNetworkReadCompleted(result);
-
- if (result == 0) // End of file.
- DoneWritingToEntry(true);
-
- return HandleResult(result);
-}
-
void HttpCache::Transaction::OnNetworkInfoAvailable(int result) {
DCHECK(result != ERR_IO_PENDING);
@@ -1614,14 +1577,9 @@ void HttpCache::Transaction::OnNetworkReadCompleted(int result) {
}
void HttpCache::Transaction::OnCacheReadCompleted(int result) {
- cache_read_callback_->Release(); // Balance the AddRef from ReadFromEntry.
DoCacheReadCompleted(result);
}
-void HttpCache::Transaction::OnCacheWriteCompleted(int result) {
- DoCacheWriteCompleted(result);
-}
-
//-----------------------------------------------------------------------------
HttpCache::HttpCache(HostResolver* host_resolver,
diff --git a/net/http/http_cache_unittest.cc b/net/http/http_cache_unittest.cc
index 2cd5154..aada69b 100644
--- a/net/http/http_cache_unittest.cc
+++ b/net/http/http_cache_unittest.cc
@@ -126,12 +126,7 @@ class MockDiskEntry : public disk_cache::Entry,
data_[index].resize(offset + buf_len);
if (buf_len)
memcpy(&data_[index][offset], buf->data(), buf_len);
-
- if (!callback || (test_mode_ & TEST_MODE_SYNC_CACHE_WRITE))
- return buf_len;
-
- CallbackLater(callback, buf_len);
- return net::ERR_IO_PENDING;
+ return buf_len;
}
virtual int ReadSparseData(int64 offset, net::IOBuffer* buf, int buf_len,
@@ -182,11 +177,7 @@ class MockDiskEntry : public disk_cache::Entry,
data_[1].resize(real_offset + buf_len);
memcpy(&data_[1][real_offset], buf->data(), buf_len);
- if (!completion_callback || (test_mode_ & TEST_MODE_SYNC_CACHE_WRITE))
- return buf_len;
-
- CallbackLater(completion_callback, buf_len);
- return net::ERR_IO_PENDING;
+ return buf_len;
}
virtual int GetAvailableRange(int64 offset, int len, int64* start) {
@@ -1978,8 +1969,7 @@ TEST(HttpCache, UnknownRangeGET_2) {
MockTransaction transaction(kRangeGET_TransactionOK);
transaction.test_mode = TEST_MODE_SYNC_CACHE_START |
- TEST_MODE_SYNC_CACHE_READ |
- TEST_MODE_SYNC_CACHE_WRITE;
+ TEST_MODE_SYNC_CACHE_READ;
AddMockTransaction(&transaction);
// Write to the cache (70-79).
@@ -2544,8 +2534,7 @@ TEST(HttpCache, SyncRead) {
ScopedMockTransaction transaction(kSimpleGET_Transaction);
transaction.test_mode |= (TEST_MODE_SYNC_CACHE_START |
- TEST_MODE_SYNC_CACHE_READ |
- TEST_MODE_SYNC_CACHE_WRITE);
+ TEST_MODE_SYNC_CACHE_READ);
MockHttpRequest r1(transaction),
r2(transaction),
diff --git a/net/http/http_transaction_unittest.h b/net/http/http_transaction_unittest.h
index a0a94f6..d2e2115 100644
--- a/net/http/http_transaction_unittest.h
+++ b/net/http/http_transaction_unittest.h
@@ -33,7 +33,6 @@ enum {
TEST_MODE_SYNC_NET_READ = 1 << 1,
TEST_MODE_SYNC_CACHE_START = 1 << 2,
TEST_MODE_SYNC_CACHE_READ = 1 << 3,
- TEST_MODE_SYNC_CACHE_WRITE = 1 << 4,
};
typedef void (*MockTransactionHandler)(const net::HttpRequestInfo* request,