summaryrefslogtreecommitdiffstats
path: root/chrome_frame/urlmon_url_request.cc
diff options
context:
space:
mode:
authorananta@chromium.org <ananta@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-12-12 01:15:07 +0000
committerananta@chromium.org <ananta@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-12-12 01:15:07 +0000
commit5c50ef53508d10638e7d32c059eef5471539d7db (patch)
treea4da6a78cb4b26f4d629d81a06f53d8422bebabc /chrome_frame/urlmon_url_request.cc
parenta540c2d2927d84f850bbe85c151e79965ae6e29b (diff)
downloadchromium_src-5c50ef53508d10638e7d32c059eef5471539d7db.zip
chromium_src-5c50ef53508d10638e7d32c059eef5471539d7db.tar.gz
chromium_src-5c50ef53508d10638e7d32c059eef5471539d7db.tar.bz2
ChromeFrame's host network stack implementation for IE should ensure that HTTP requests issued by Chrome
which terminate without any data complete correctly, i.e. we send over the request end notification to Chrome. This ensures that Chrome does not wait forever for the request to complete. This fixes http://code.google.com/p/chromium/issues/detail?id=30149, which shows up on certain sites where the throbber continues to spin at times and at times pages show up blank. Bug=30149 Test=Launch ChromeFrame in IE and navigate to cf:http://www.tennisballcricket.org. We should not see a blank page. Will look into a unit test for this. Review URL: http://codereview.chromium.org/491057 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@34400 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome_frame/urlmon_url_request.cc')
-rw-r--r--chrome_frame/urlmon_url_request.cc16
1 files changed, 14 insertions, 2 deletions
diff --git a/chrome_frame/urlmon_url_request.cc b/chrome_frame/urlmon_url_request.cc
index 2e39bea..49de036 100644
--- a/chrome_frame/urlmon_url_request.cc
+++ b/chrome_frame/urlmon_url_request.cc
@@ -214,8 +214,10 @@ STDMETHODIMP UrlmonUrlRequest::OnProgress(ULONG progress, ULONG max_progress,
OnResponse(0, UTF8ToWide(headers).c_str(), NULL, NULL);
ignore_redirect_stop_binding_error_ = true;
DCHECK(binding_ != NULL);
- binding_->Abort();
- binding_ = NULL;
+ if (binding_) {
+ binding_->Abort();
+ binding_ = NULL;
+ }
return E_ABORT;
}
@@ -244,6 +246,15 @@ STDMETHODIMP UrlmonUrlRequest::OnStopBinding(HRESULT result, LPCWSTR error) {
status_.set_status(URLRequestStatus::SUCCESS);
status_.set_os_error(0);
ReleaseBindings();
+ // In most cases we receive the end request notification from Chrome.
+ // However at times requests can complete without us receiving any
+ // data. In this case we need to inform Chrome that this request has been
+ // completed to prevent Chrome from waiting forever for data for this
+ // request.
+ if (pending_read_size_) {
+ pending_read_size_ = 0;
+ OnResponseEnd(status_);
+ }
}
return S_OK;
@@ -332,6 +343,7 @@ STDMETHODIMP UrlmonUrlRequest::OnDataAvailable(DWORD flags, DWORD size,
cached_data_.Read(&send_stream, pending_read_size_, &pending_read_size_);
DLOG(INFO) << StringPrintf("URL: %s Obj: %X", url().c_str(), this) <<
" - size read: " << pending_read_size_;
+ pending_read_size_ = 0;
} else {
DLOG(INFO) << StringPrintf("URL: %s Obj: %X", url().c_str(), this) <<
" - waiting for remote read";