| Index: content/browser/web_contents/web_contents_impl.cc
|
| diff --git a/content/browser/web_contents/web_contents_impl.cc b/content/browser/web_contents/web_contents_impl.cc
|
| index 6f7e538490d542c915f54e4169880ea7a4f97204..bd34c278fec1dabbaaeb2b17275d159ca9eeb635 100644
|
| --- a/content/browser/web_contents/web_contents_impl.cc
|
| +++ b/content/browser/web_contents/web_contents_impl.cc
|
| @@ -1538,6 +1538,7 @@ void WebContentsImpl::Init(const WebContents::CreateParams& params) {
|
|
|
| if (!view_) {
|
| if (browser_plugin_guest_ &&
|
| + !browser_plugin_guest_->IsMimeHandlerViewGuest() &&
|
| BrowserPluginGuestMode::UseCrossProcessFramesForGuests()) {
|
| view_.reset(new WebContentsViewChildFrame(
|
| this, delegate, &render_view_host_delegate_view_));
|
| @@ -1548,7 +1549,8 @@ void WebContentsImpl::Init(const WebContents::CreateParams& params) {
|
| }
|
|
|
| if (browser_plugin_guest_ &&
|
| - !BrowserPluginGuestMode::UseCrossProcessFramesForGuests()) {
|
| + (!BrowserPluginGuestMode::UseCrossProcessFramesForGuests() ||
|
| + browser_plugin_guest_->IsMimeHandlerViewGuest())) {
|
| view_.reset(new WebContentsViewGuest(this, browser_plugin_guest_.get(),
|
| std::move(view_),
|
| &render_view_host_delegate_view_));
|
| @@ -4576,7 +4578,9 @@ void WebContentsImpl::EnsureOpenerProxiesExist(RenderFrameHost* source_rfh) {
|
| // then we should not create a RenderView. AttachToOuterWebContentsFrame()
|
| // already created a RenderFrameProxyHost for that purpose.
|
| if (GetBrowserPluginEmbedder() &&
|
| - BrowserPluginGuestMode::UseCrossProcessFramesForGuests()) {
|
| + BrowserPluginGuestMode::UseCrossProcessFramesForGuests() &&
|
| + !source_web_contents->GetBrowserPluginGuest()
|
| + ->IsMimeHandlerViewGuest()) {
|
| return;
|
| }
|
|
|
| @@ -4979,12 +4983,14 @@ RenderFrameHostManager* WebContentsImpl::GetRenderManager() const {
|
| }
|
|
|
| WebContentsImpl* WebContentsImpl::GetOuterWebContents() {
|
| - if (BrowserPluginGuestMode::UseCrossProcessFramesForGuests()) {
|
| + if (BrowserPluginGuestMode::UseCrossProcessFramesForGuests() &&
|
| + (!browser_plugin_guest_ ||
|
| + !browser_plugin_guest_->IsMimeHandlerViewGuest())) {
|
| if (node_)
|
| return node_->outer_web_contents();
|
| } else {
|
| - if (GetBrowserPluginGuest())
|
| - return GetBrowserPluginGuest()->embedder_web_contents();
|
| + if (browser_plugin_guest_)
|
| + return browser_plugin_guest_->embedder_web_contents();
|
| }
|
| return nullptr;
|
| }
|
|
|