mirror of
				https://bitbucket.org/chromiumembedded/cef
				synced 2025-06-05 21:39:12 +02:00 
			
		
		
		
	Remove usage of FrameTreeNode IDs (see issue #2421)
With the introduction of prerendering in Chromium it is now possible for RenderFrameHosts (RFH) to move between FrameTrees. As a consequence we can no longer rely on FrameTreeNode IDs to uniquely identify a RFH over its lifespan. We must now switch to using GlobalRenderFrameHostId (child_id, frame_routing_id) instead for that purpose. Additionally, we simplify existing code by using the GlobalRenderFrameHostId struct in all places that previously used a (render_process_id, render_frame_id) pair, since these concepts are equivalent. See https://crbug.com/1179502#c8 for additional background.
This commit is contained in:
		| @@ -6,6 +6,7 @@ | ||||
|  | ||||
| #include "libcef/browser/browser_info_manager.h" | ||||
| #include "libcef/browser/origin_whitelist_impl.h" | ||||
| #include "libcef/common/frame_util.h" | ||||
|  | ||||
| #include "content/public/browser/render_process_host.h" | ||||
| #include "mojo/public/cpp/bindings/pending_receiver.h" | ||||
| @@ -52,5 +53,6 @@ void CefBrowserManager::GetNewBrowserInfo( | ||||
|     int32_t render_frame_routing_id, | ||||
|     cef::mojom::BrowserManager::GetNewBrowserInfoCallback callback) { | ||||
|   CefBrowserInfoManager::GetInstance()->OnGetNewBrowserInfo( | ||||
|       render_process_id_, render_frame_routing_id, std::move(callback)); | ||||
|       frame_util::MakeGlobalId(render_process_id_, render_frame_routing_id), | ||||
|       std::move(callback)); | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user