diff options
author | ananta@chromium.org <ananta@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-04-20 23:27:29 +0000 |
---|---|---|
committer | ananta@chromium.org <ananta@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-04-20 23:27:29 +0000 |
commit | 29c32f903806efbc167a417c170b896dfeecc33f (patch) | |
tree | 3c05f7208c27e1affa40d859b573f5a1a6bc66d8 /chrome_frame/urlmon_bind_status_callback.cc | |
parent | 735f05d9e40970195459ac9136e8e731edea4f32 (diff) | |
download | chromium_src-29c32f903806efbc167a417c170b896dfeecc33f.zip chromium_src-29c32f903806efbc167a417c170b896dfeecc33f.tar.gz chromium_src-29c32f903806efbc167a417c170b896dfeecc33f.tar.bz2 |
In ChromeFrame with the IMoniker patch on, we should save away the redirect information received for the initial pending request. This
is to ensure that we inform Chrome about this redirect which can then be followed correctly from Chrome.
The other change is to save away the URL being navigated to in the bind context context object. This is also updated if we receive a redirect
notification in our callback wrapper. The active document refers this URL if it is available and falls back to the old mechanism of retrieving
the URL from the moniker if not.
This ensures that optin urls continue to work correctly if the initial page is redirected.
Review URL: http://codereview.chromium.org/1523028
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@45114 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome_frame/urlmon_bind_status_callback.cc')
-rw-r--r-- | chrome_frame/urlmon_bind_status_callback.cc | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/chrome_frame/urlmon_bind_status_callback.cc b/chrome_frame/urlmon_bind_status_callback.cc index c870f7ad..8d724f4 100644 --- a/chrome_frame/urlmon_bind_status_callback.cc +++ b/chrome_frame/urlmon_bind_status_callback.cc @@ -88,7 +88,6 @@ bool SniffData::InitializeCache(const std::wstring& url) { NOTREACHED(); return false; } - return true; } @@ -213,6 +212,12 @@ STDMETHODIMP BSCBStorageBind::OnProgress(ULONG progress, ULONG progress_max, Progress new_progress = { progress, progress_max, status_code, status_text ? status_text : std::wstring() }; saved_progress_.push_back(new_progress); + if (status_code == BINDSTATUS_REDIRECTING) { + scoped_refptr<BindContextInfo> info = + BindContextInfo::FromBindContext(bind_ctx_); + DCHECK(info); + info->set_url(status_text); + } } else { hr = CallbackImpl::OnProgress(progress, progress_max, status_code, status_text); |