Fix crash due to site_instace being freed early
This commit is contained in:
parent
899cdb48d7
commit
530f19e956
1 changed files with 10 additions and 0 deletions
|
@ -52,6 +52,9 @@ bool g_suppress_renderer_process_restart = false;
|
||||||
// Custom schemes to be registered to handle service worker.
|
// Custom schemes to be registered to handle service worker.
|
||||||
std::string g_custom_service_worker_schemes = "";
|
std::string g_custom_service_worker_schemes = "";
|
||||||
|
|
||||||
|
void Noop(scoped_refptr<content::SiteInstance>) {
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
// static
|
// static
|
||||||
|
@ -133,6 +136,13 @@ void AtomBrowserClient::OverrideSiteInstanceForNavigation(
|
||||||
content::SiteInstance::CreateForURL(browser_context, url);
|
content::SiteInstance::CreateForURL(browser_context, url);
|
||||||
*new_instance = site_instance.get();
|
*new_instance = site_instance.get();
|
||||||
|
|
||||||
|
// Make sure the |site_instance| is not freed when this function returns.
|
||||||
|
// FIXME(zcbenz): We should adjust OverrideSiteInstanceForNavigation's
|
||||||
|
// interface to solve this.
|
||||||
|
content::BrowserThread::PostTask(
|
||||||
|
content::BrowserThread::UI, FROM_HERE,
|
||||||
|
base::Bind(&Noop, base::RetainedRef(site_instance)));
|
||||||
|
|
||||||
// Remember the original renderer process of the pending renderer process.
|
// Remember the original renderer process of the pending renderer process.
|
||||||
auto current_process = current_instance->GetProcess();
|
auto current_process = current_instance->GetProcess();
|
||||||
auto pending_process = (*new_instance)->GetProcess();
|
auto pending_process = (*new_instance)->GetProcess();
|
||||||
|
|
Loading…
Reference in a new issue