diff options
-rw-r--r-- | chrome_frame/protocol_sink_wrap.cc | 12 | ||||
-rw-r--r-- | chrome_frame/protocol_sink_wrap.h | 4 |
2 files changed, 15 insertions, 1 deletions
diff --git a/chrome_frame/protocol_sink_wrap.cc b/chrome_frame/protocol_sink_wrap.cc index cbafc8f..42ed4ff 100644 --- a/chrome_frame/protocol_sink_wrap.cc +++ b/chrome_frame/protocol_sink_wrap.cc @@ -65,7 +65,8 @@ CComAutoCriticalSection ProtocolSinkWrap::sink_map_lock_; ProtocolSinkWrap::ProtocolSinkWrap() : protocol_(NULL), renderer_type_(UNDETERMINED), buffer_size_(0), buffer_pos_(0), is_saved_result_(false), - result_code_(0), result_error_(0), report_data_recursiveness_(0) { + result_code_(0), result_error_(0), report_data_recursiveness_(0), + determining_renderer_type_(false) { memset(buffer_, 0, arraysize(buffer_)); } @@ -566,6 +567,13 @@ HRESULT ProtocolSinkWrap::CheckAndReportChromeMimeTypeForRequest() { if (!is_undetermined()) return S_OK; + // This function could get invoked recursively in the context of + // IInternetProtocol::Read. Check for the same and bail. + if (determining_renderer_type_) + return S_OK; + + determining_renderer_type_ = true; + HRESULT hr_read = S_OK; while (hr_read == S_OK) { ULONG size_read = 0; @@ -599,6 +607,8 @@ HRESULT ProtocolSinkWrap::CheckAndReportChromeMimeTypeForRequest() { break; } } + + determining_renderer_type_ = false; return hr_read; } diff --git a/chrome_frame/protocol_sink_wrap.h b/chrome_frame/protocol_sink_wrap.h index 4596b58..53812ba 100644 --- a/chrome_frame/protocol_sink_wrap.h +++ b/chrome_frame/protocol_sink_wrap.h @@ -237,6 +237,10 @@ END_COM_MAP() std::wstring url_; + // Set to true if we are in the context of determining the desired renderer + // type. + bool determining_renderer_type_; + private: DISALLOW_COPY_AND_ASSIGN(ProtocolSinkWrap); }; |