fix: account for potentially swapped FrameTreeNodeId in WebFrameMain (#41594)

fix: account for potentially swapped FrameTreeNodeId in WebFrameMain

Co-authored-by: trop[bot] <37223003+trop[bot]@users.noreply.github.com>
Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com>
This commit is contained in:
trop[bot] 2024-03-14 13:02:09 -04:00 committed by GitHub
parent b713e34947
commit ee4bbb5851
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -72,7 +72,17 @@ WebFrameMain* WebFrameMain::FromFrameTreeNodeId(int frame_tree_node_id) {
// static // static
WebFrameMain* WebFrameMain::FromRenderFrameHost(content::RenderFrameHost* rfh) { WebFrameMain* WebFrameMain::FromRenderFrameHost(content::RenderFrameHost* rfh) {
return rfh ? FromFrameTreeNodeId(rfh->GetFrameTreeNodeId()) : nullptr; if (!rfh)
return nullptr;
// TODO(codebytere): remove after refactoring away from FrameTreeNodeId as map
// key.
auto* ftn =
static_cast<content::RenderFrameHostImpl*>(rfh)->frame_tree_node();
if (!ftn)
return nullptr;
return FromFrameTreeNodeId(rfh->GetFrameTreeNodeId());
} }
gin::WrapperInfo WebFrameMain::kWrapperInfo = {gin::kEmbedderNativeGin}; gin::WrapperInfo WebFrameMain::kWrapperInfo = {gin::kEmbedderNativeGin};
@ -358,8 +368,9 @@ gin::Handle<WebFrameMain> WebFrameMain::New(v8::Isolate* isolate) {
// static // static
gin::Handle<WebFrameMain> WebFrameMain::From(v8::Isolate* isolate, gin::Handle<WebFrameMain> WebFrameMain::From(v8::Isolate* isolate,
content::RenderFrameHost* rfh) { content::RenderFrameHost* rfh) {
if (rfh == nullptr) if (!rfh)
return gin::Handle<WebFrameMain>(); return gin::Handle<WebFrameMain>();
auto* web_frame = FromRenderFrameHost(rfh); auto* web_frame = FromRenderFrameHost(rfh);
if (web_frame) if (web_frame)
return gin::CreateHandle(isolate, web_frame); return gin::CreateHandle(isolate, web_frame);
@ -376,12 +387,14 @@ gin::Handle<WebFrameMain> WebFrameMain::From(v8::Isolate* isolate,
gin::Handle<WebFrameMain> WebFrameMain::FromOrNull( gin::Handle<WebFrameMain> WebFrameMain::FromOrNull(
v8::Isolate* isolate, v8::Isolate* isolate,
content::RenderFrameHost* rfh) { content::RenderFrameHost* rfh) {
if (rfh == nullptr) if (!rfh)
return gin::Handle<WebFrameMain>(); return gin::Handle<WebFrameMain>();
auto* web_frame = FromRenderFrameHost(rfh); auto* web_frame = FromRenderFrameHost(rfh);
if (web_frame) if (!web_frame)
return gin::CreateHandle(isolate, web_frame);
return gin::Handle<WebFrameMain>(); return gin::Handle<WebFrameMain>();
return gin::CreateHandle(isolate, web_frame);
} }
// static // static