diff options
author | amit@chromium.org <amit@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-04-14 00:35:52 +0000 |
---|---|---|
committer | amit@chromium.org <amit@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-04-14 00:35:52 +0000 |
commit | 3ee6112cc9d368ccd11d2cc2eea4f3aca2fd4400 (patch) | |
tree | f4b1f729762acbdd4ee3903f0b29d04f77b1b952 /chrome_frame/urlmon_bind_status_callback.cc | |
parent | 72eb2da638af5bcb4830827eeb1edebb580e36b1 (diff) | |
download | chromium_src-3ee6112cc9d368ccd11d2cc2eea4f3aca2fd4400.zip chromium_src-3ee6112cc9d368ccd11d2cc2eea4f3aca2fd4400.tar.gz chromium_src-3ee6112cc9d368ccd11d2cc2eea4f3aca2fd4400.tar.bz2 |
Fix for remaining major issues with moniker patch
This patch fixes things so that they now work 'naturally', i.e switch
to chrome frame looks just like switching to pdf. The same bind context
and underlying network transaction objects are used and requests aren't
sent multiple times. Finally the TestPostReissue test is happy!
This patch fixes two issues with earlier scheme:
Issue 1: data can be read only once from a given bind context. Mshtml
looks at the mime type in the FORMATETC but never issues a read. So when
it switches, the new active document can read from start. Since we are
reading the data for switching, when we actually switch, we have to
transfer over the data read so far to our UrlmonUrlRequest.
Issue 2: The very first UrlmomUrlRequest has to start binding right away,
in the context of BindToStorage or network transcations associated with
the bind context are gone (due to OnStopBinding for BindToObject).
TEST=covered by existing tests
BUG=33332
Review URL: http://codereview.chromium.org/1508033
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@44427 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 | 41 |
1 files changed, 27 insertions, 14 deletions
diff --git a/chrome_frame/urlmon_bind_status_callback.cc b/chrome_frame/urlmon_bind_status_callback.cc index 0681849..cf920c2 100644 --- a/chrome_frame/urlmon_bind_status_callback.cc +++ b/chrome_frame/urlmon_bind_status_callback.cc @@ -81,11 +81,8 @@ bool SniffData::InitializeCache(const std::wstring& url) { url_ = url; renderer_type_ = UNDETERMINED; - const int kAllocationSize = 32 * 1024; - HGLOBAL memory = GlobalAlloc(0, kAllocationSize); - HRESULT hr = CreateStreamOnHGlobal(memory, TRUE, cache_.Receive()); + HRESULT hr = CreateStreamOnHGlobal(NULL, TRUE, cache_.Receive()); if (FAILED(hr)) { - GlobalFree(memory); NOTREACHED(); return false; } @@ -182,7 +179,8 @@ void SniffData::DetermineRendererType() { ///////////////////////////////////////////////////////////////////// -HRESULT BSCBStorageBind::Initialize(IMoniker* moniker, IBindCtx* bind_ctx) { +HRESULT BSCBStorageBind::Initialize(IMoniker* moniker, IBindCtx* bind_ctx, + bool no_cache) { DLOG(INFO) << __FUNCTION__ << me() << StringPrintf(" tid=%i", PlatformThread::CurrentId()); @@ -200,6 +198,7 @@ HRESULT BSCBStorageBind::Initialize(IMoniker* moniker, IBindCtx* bind_ctx) { std::wstring url = GetActualUrlFromMoniker(moniker, bind_ctx, std::wstring()); data_sniffer_.InitializeCache(url); + no_cache_ = no_cache; return hr; } @@ -227,13 +226,15 @@ STDMETHODIMP BSCBStorageBind::OnDataAvailable(DWORD flags, DWORD size, STGMEDIUM* stgmed) { DLOG(INFO) << __FUNCTION__ << StringPrintf(" tid=%i", PlatformThread::CurrentId()); - if (!stgmed || !format_etc) { - DLOG(INFO) << __FUNCTION__ << me() << "Invalid stgmed or format_etc"; - return CallbackImpl::OnDataAvailable(flags, size, format_etc, stgmed); - } - if ((stgmed->tymed != TYMED_ISTREAM) || !stgmed->pstm) { - DLOG(INFO) << __FUNCTION__ << me() << "stgmedium is not a valid stream"; + // Do not touch anything other than text/html. + const CLIPFORMAT text_html = RegisterClipboardFormat(CFSTR_MIME_HTML); + bool is_interesting = (format_etc && stgmed && stgmed->pstm && + (stgmed->tymed == TYMED_ISTREAM) && (text_html == format_etc->cfFormat)); + + if (!is_interesting) { + // Play back report progress so far. + MayPlayBack(flags); return CallbackImpl::OnDataAvailable(flags, size, format_etc, stgmed); } @@ -309,13 +310,25 @@ HRESULT BSCBStorageBind::MayPlayBack(DWORD flags) { } if (data_sniffer_.is_cache_valid()) { + if (data_sniffer_.is_chrome()) { + ScopedComPtr<IStream> cache; + if (no_cache_) { + // This flag is set by BindToObject indicating taht we don't need + // to cache as we'll be able to read data from the bind later. + CreateStreamOnHGlobal(NULL, TRUE, cache.Receive()); + } else { + // Binding began with BindToStorage and the data cann't be read + // back so pass on the data read so far. + cache = data_sniffer_.cache_; + } + DCHECK(cache); + NavigationManager::SetForSwitch(bind_ctx_, cache); + } + hr = data_sniffer_.DrainCache(delegate(), flags | BSCF_FIRSTDATANOTIFICATION, clip_format_); DLOG_IF(WARNING, INET_E_TERMINATED_BIND != hr) << __FUNCTION__ << " mshtml OnDataAvailable returned: " << std::hex << hr; - if (data_sniffer_.is_chrome()) { - NavigationManager::SetForSwitch(bind_ctx_); - } } return hr; |