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 6b1407b78e0ace939218a24a5478b0c23d48f1c3..da144a40491a95f1747d35c818a2aeb6716a9cb3 100644 |
--- a/content/browser/web_contents/web_contents_impl.cc |
+++ b/content/browser/web_contents/web_contents_impl.cc |
@@ -279,15 +279,16 @@ void WebContentsImpl::FriendZone::RemoveCreatedCallbackForTesting( |
} |
} |
-WebContents* WebContents::FromRenderViewHost(const RenderViewHost* rvh) { |
+WebContents* WebContents::FromRenderViewHost(RenderViewHost* rvh) { |
+ if (!rvh) |
+ return nullptr; |
return rvh->GetDelegate()->GetAsWebContents(); |
} |
WebContents* WebContents::FromRenderFrameHost(RenderFrameHost* rfh) { |
- RenderFrameHostImpl* rfh_impl = static_cast<RenderFrameHostImpl*>(rfh); |
- if (!rfh_impl) |
- return NULL; |
- return rfh_impl->delegate()->GetAsWebContents(); |
+ if (!rfh) |
+ return nullptr; |
+ return static_cast<RenderFrameHostImpl*>(rfh)->delegate()->GetAsWebContents(); |
} |
// WebContentsImpl::DestructionObserver ---------------------------------------- |
@@ -546,21 +547,18 @@ std::vector<WebContentsImpl*> WebContentsImpl::GetAllWebContents() { |
std::vector<WebContentsImpl*> result; |
scoped_ptr<RenderWidgetHostIterator> widgets( |
RenderWidgetHostImpl::GetRenderWidgetHosts()); |
- std::set<WebContentsImpl*> web_contents_set; |
while (RenderWidgetHost* rwh = widgets->GetNextHost()) { |
- if (!rwh->IsRenderView()) |
- continue; |
RenderViewHost* rvh = RenderViewHost::From(rwh); |
if (!rvh) |
continue; |
WebContents* web_contents = WebContents::FromRenderViewHost(rvh); |
if (!web_contents) |
continue; |
- WebContentsImpl* wci = static_cast<WebContentsImpl*>(web_contents); |
- if (web_contents_set.find(wci) == web_contents_set.end()) { |
- web_contents_set.insert(wci); |
- result.push_back(wci); |
- } |
+ if (web_contents->GetRenderViewHost() != rvh) |
+ continue; |
+ // Because a WebContents can only have one current RVH at a time, there will |
+ // be no duplicate WebContents here. |
+ result.push_back(static_cast<WebContentsImpl*>(web_contents)); |
} |
return result; |
} |