| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "extensions/browser/guest_view/web_view/web_view_guest.h" | 5 #include "extensions/browser/guest_view/web_view/web_view_guest.h" |
| 6 | 6 |
| 7 #include "base/message_loop/message_loop.h" | 7 #include "base/message_loop/message_loop.h" |
| 8 #include "base/strings/stringprintf.h" | 8 #include "base/strings/stringprintf.h" |
| 9 #include "base/strings/utf_string_conversions.h" | 9 #include "base/strings/utf_string_conversions.h" |
| 10 #include "components/browsing_data/storage_partition_http_cache_data_remover.h" | 10 #include "components/browsing_data/storage_partition_http_cache_data_remover.h" |
| (...skipping 179 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 190 } | 190 } |
| 191 | 191 |
| 192 using WebViewKey = std::pair<int, int>; | 192 using WebViewKey = std::pair<int, int>; |
| 193 using WebViewKeyToIDMap = std::map<WebViewKey, int>; | 193 using WebViewKeyToIDMap = std::map<WebViewKey, int>; |
| 194 static base::LazyInstance<WebViewKeyToIDMap> web_view_key_to_id_map = | 194 static base::LazyInstance<WebViewKeyToIDMap> web_view_key_to_id_map = |
| 195 LAZY_INSTANCE_INITIALIZER; | 195 LAZY_INSTANCE_INITIALIZER; |
| 196 | 196 |
| 197 } // namespace | 197 } // namespace |
| 198 | 198 |
| 199 // static | 199 // static |
| 200 void WebViewGuest::CleanUp(int embedder_process_id, int view_instance_id) { | 200 void WebViewGuest::CleanUp(content::BrowserContext* browser_context, |
| 201 GuestViewBase::CleanUp(embedder_process_id, view_instance_id); | 201 int embedder_process_id, |
| 202 | 202 int view_instance_id) { |
| 203 auto rph = content::RenderProcessHost::FromID(embedder_process_id); | 203 GuestViewBase::CleanUp(browser_context, embedder_process_id, |
| 204 // TODO(paulmeyer): It should be impossible for rph to be nullptr here, but | 204 view_instance_id); |
| 205 // this check is needed here for now as there seems to be occasional crashes | |
| 206 // because of this (http//crbug.com/499438). This should be removed once the | |
| 207 // cause is discovered and fixed. | |
| 208 DCHECK(rph != nullptr) | |
| 209 << "Cannot find RenderProcessHost for embedder process ID# " | |
| 210 << embedder_process_id; | |
| 211 if (rph == nullptr) | |
| 212 return; | |
| 213 auto browser_context = rph->GetBrowserContext(); | |
| 214 | 205 |
| 215 // Clean up rules registries for the WebView. | 206 // Clean up rules registries for the WebView. |
| 216 WebViewKey key(embedder_process_id, view_instance_id); | 207 WebViewKey key(embedder_process_id, view_instance_id); |
| 217 auto it = web_view_key_to_id_map.Get().find(key); | 208 auto it = web_view_key_to_id_map.Get().find(key); |
| 218 if (it != web_view_key_to_id_map.Get().end()) { | 209 if (it != web_view_key_to_id_map.Get().end()) { |
| 219 auto rules_registry_id = it->second; | 210 auto rules_registry_id = it->second; |
| 220 web_view_key_to_id_map.Get().erase(it); | 211 web_view_key_to_id_map.Get().erase(it); |
| 221 RulesRegistryService::Get(browser_context) | 212 RulesRegistryService* rrs = |
| 222 ->RemoveRulesRegistriesByID(rules_registry_id); | 213 RulesRegistryService::Get(browser_context, false /* create */); |
| 214 if (rrs) |
| 215 rrs->RemoveRulesRegistriesByID(rules_registry_id); |
| 223 } | 216 } |
| 224 | 217 |
| 225 // Clean up web request event listeners for the WebView. | 218 // Clean up web request event listeners for the WebView. |
| 226 content::BrowserThread::PostTask( | 219 content::BrowserThread::PostTask( |
| 227 content::BrowserThread::IO, | 220 content::BrowserThread::IO, |
| 228 FROM_HERE, | 221 FROM_HERE, |
| 229 base::Bind( | 222 base::Bind( |
| 230 &RemoveWebViewEventListenersOnIOThread, | 223 &RemoveWebViewEventListenersOnIOThread, |
| 231 browser_context, | 224 browser_context, |
| 232 embedder_process_id, | 225 embedder_process_id, |
| (...skipping 1217 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1450 scoped_ptr<base::DictionaryValue> args(new base::DictionaryValue()); | 1443 scoped_ptr<base::DictionaryValue> args(new base::DictionaryValue()); |
| 1451 DispatchEventToView( | 1444 DispatchEventToView( |
| 1452 new GuestViewEvent(webview::kEventExitFullscreen, args.Pass())); | 1445 new GuestViewEvent(webview::kEventExitFullscreen, args.Pass())); |
| 1453 } | 1446 } |
| 1454 // Since we changed fullscreen state, sending a Resize message ensures that | 1447 // Since we changed fullscreen state, sending a Resize message ensures that |
| 1455 // renderer/ sees the change. | 1448 // renderer/ sees the change. |
| 1456 web_contents()->GetRenderViewHost()->WasResized(); | 1449 web_contents()->GetRenderViewHost()->WasResized(); |
| 1457 } | 1450 } |
| 1458 | 1451 |
| 1459 } // namespace extensions | 1452 } // namespace extensions |
| OLD | NEW |