summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--chrome_frame/protocol_sink_wrap.cc12
-rw-r--r--chrome_frame/protocol_sink_wrap.h4
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);
};