diff options
Diffstat (limited to 'chromium/weblayer/browser/persistence/browser_persister.cc')
-rw-r--r-- | chromium/weblayer/browser/persistence/browser_persister.cc | 22 |
1 files changed, 17 insertions, 5 deletions
diff --git a/chromium/weblayer/browser/persistence/browser_persister.cc b/chromium/weblayer/browser/persistence/browser_persister.cc index c7fe1a5c325..fac791261ab 100644 --- a/chromium/weblayer/browser/persistence/browser_persister.cc +++ b/chromium/weblayer/browser/persistence/browser_persister.cc @@ -18,13 +18,13 @@ #include "components/sessions/core/session_constants.h" #include "components/sessions/core/session_id.h" #include "components/sessions/core/session_types.h" -#include "content/public/browser/browser_context.h" #include "content/public/browser/navigation_details.h" #include "content/public/browser/navigation_entry.h" #include "content/public/browser/restore_type.h" #include "content/public/browser/session_storage_namespace.h" #include "content/public/browser/storage_partition.h" #include "content/public/browser/web_contents.h" +#include "weblayer/browser/browser_context_impl.h" #include "weblayer/browser/browser_impl.h" #include "weblayer/browser/persistence/browser_persistence_common.h" #include "weblayer/browser/profile_impl.h" @@ -105,8 +105,9 @@ void BrowserPersister::OnGeneratedNewCryptoKey( } void BrowserPersister::OnTabAdded(Tab* tab) { - content::WebContents* web_contents = - static_cast<TabImpl*>(tab)->web_contents(); + auto* tab_impl = static_cast<TabImpl*>(tab); + data_observer_.Add(tab_impl); + content::WebContents* web_contents = tab_impl->web_contents(); auto* tab_helper = sessions::SessionTabHelper::FromWebContents(web_contents); DCHECK(tab_helper); tab_helper->SetWindowID(browser_session_id_); @@ -130,10 +131,11 @@ void BrowserPersister::OnTabAdded(Tab* tab) { } void BrowserPersister::OnTabRemoved(Tab* tab, bool active_tab_changed) { + auto* tab_impl = static_cast<TabImpl*>(tab); + data_observer_.Remove(tab_impl); // Allow the associated sessionStorage to get deleted; it won't be needed // in the session restore. - content::WebContents* web_contents = - static_cast<TabImpl*>(tab)->web_contents(); + content::WebContents* web_contents = tab_impl->web_contents(); content::SessionStorageNamespace* session_storage_namespace = web_contents->GetController().GetDefaultSessionStorageNamespace(); session_storage_namespace->SetShouldPersist(false); @@ -161,6 +163,16 @@ void BrowserPersister::OnActiveTabChanged(Tab* tab) { browser_session_id_, index)); } +void BrowserPersister::OnDataChanged( + TabImpl* tab, + const std::map<std::string, std::string>& data) { + if (rebuild_on_next_save_) + return; + + ScheduleCommand( + sessions::CreateSetTabDataCommand(GetSessionIDForTab(tab), data)); +} + void BrowserPersister::SetTabUserAgentOverride( const SessionID& window_id, const SessionID& tab_id, |