OLD | NEW |
---|---|
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 #ifndef CONTENT_BROWSER_FRAME_HOST_RENDER_VIEW_HOST_MANAGER_H_ | 5 #ifndef CONTENT_BROWSER_FRAME_HOST_RENDER_VIEW_HOST_MANAGER_H_ |
6 #define CONTENT_BROWSER_FRAME_HOST_RENDER_VIEW_HOST_MANAGER_H_ | 6 #define CONTENT_BROWSER_FRAME_HOST_RENDER_VIEW_HOST_MANAGER_H_ |
7 | 7 |
8 #include "base/basictypes.h" | 8 #include "base/basictypes.h" |
9 #include "base/logging.h" | 9 #include "base/logging.h" |
10 #include "base/memory/scoped_ptr.h" | 10 #include "base/memory/scoped_ptr.h" |
(...skipping 281 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
292 // cross-site URLs. Enabled unless we see the --process-per-tab command line | 292 // cross-site URLs. Enabled unless we see the --process-per-tab command line |
293 // switch. Can be overridden in unit tests. | 293 // switch. Can be overridden in unit tests. |
294 bool ShouldTransitionCrossSite(); | 294 bool ShouldTransitionCrossSite(); |
295 | 295 |
296 // Returns true if the two navigation entries are incompatible in some way | 296 // Returns true if the two navigation entries are incompatible in some way |
297 // other than site instances. Cases where this can happen include Web UI | 297 // other than site instances. Cases where this can happen include Web UI |
298 // to regular web pages. It will cause us to swap RenderViewHosts (and hence | 298 // to regular web pages. It will cause us to swap RenderViewHosts (and hence |
299 // RenderProcessHosts) even if the site instance would otherwise be the same. | 299 // RenderProcessHosts) even if the site instance would otherwise be the same. |
300 // As part of this, we'll also force new SiteInstances and BrowsingInstances. | 300 // As part of this, we'll also force new SiteInstances and BrowsingInstances. |
301 // Either of the entries may be NULL. | 301 // Either of the entries may be NULL. |
302 // TODO(creis): Rename to ShouldSwapBrowsingInstancesForNavigation. | |
302 bool ShouldSwapProcessesForNavigation( | 303 bool ShouldSwapProcessesForNavigation( |
303 const NavigationEntry* curr_entry, | 304 const NavigationEntry* curr_entry, |
304 const NavigationEntryImpl* new_entry) const; | 305 const NavigationEntryImpl* new_entry) const; |
305 | 306 |
306 bool ShouldReuseWebUI( | 307 bool ShouldReuseWebUI( |
307 const NavigationEntry* curr_entry, | 308 const NavigationEntry* curr_entry, |
308 const NavigationEntryImpl* new_entry) const; | 309 const NavigationEntryImpl* new_entry) const; |
309 | 310 |
310 // Returns an appropriate SiteInstance object for the given NavigationEntry, | 311 // Returns an appropriate SiteInstance object for the given NavigationEntry, |
311 // possibly reusing the current SiteInstance. | 312 // possibly reusing the current SiteInstance. If --process-per-tab is used, |
312 // Never called if --process-per-tab is used. | 313 // this is only called when ShouldSwapProcessesForNavigation reutrns true. |
ncarter (slow)
2013/11/12 03:38:26
typo "reutrns"
Charlie Reis
2013/11/12 16:09:35
Done.
| |
313 SiteInstance* GetSiteInstanceForEntry( | 314 SiteInstance* GetSiteInstanceForEntry( |
314 const NavigationEntryImpl& entry, | 315 const NavigationEntryImpl& entry, |
315 SiteInstance* curr_instance); | 316 SiteInstance* curr_instance, |
317 bool force_browsing_instance_swap); | |
316 | 318 |
317 // Sets up the necessary state for a new RenderViewHost with the given opener. | 319 // Sets up the necessary state for a new RenderViewHost with the given opener. |
318 bool InitRenderView(RenderViewHost* render_view_host, int opener_route_id); | 320 bool InitRenderView(RenderViewHost* render_view_host, int opener_route_id); |
319 | 321 |
320 // Sets the pending RenderViewHost/WebUI to be the active one. Note that this | 322 // Sets the pending RenderViewHost/WebUI to be the active one. Note that this |
321 // doesn't require the pending render_view_host_ pointer to be non-NULL, since | 323 // doesn't require the pending render_view_host_ pointer to be non-NULL, since |
322 // there could be Web UI switching as well. Call this for every commit. | 324 // there could be Web UI switching as well. Call this for every commit. |
323 void CommitPending(); | 325 void CommitPending(); |
324 | 326 |
325 // Shutdown all RenderViewHosts in a SiteInstance. This is called | 327 // Shutdown all RenderViewHosts in a SiteInstance. This is called |
(...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
388 InterstitialPageImpl* interstitial_page_; | 390 InterstitialPageImpl* interstitial_page_; |
389 | 391 |
390 NotificationRegistrar registrar_; | 392 NotificationRegistrar registrar_; |
391 | 393 |
392 DISALLOW_COPY_AND_ASSIGN(RenderViewHostManager); | 394 DISALLOW_COPY_AND_ASSIGN(RenderViewHostManager); |
393 }; | 395 }; |
394 | 396 |
395 } // namespace content | 397 } // namespace content |
396 | 398 |
397 #endif // CONTENT_BROWSER_FRAME_HOST_RENDER_VIEW_HOST_MANAGER_H_ | 399 #endif // CONTENT_BROWSER_FRAME_HOST_RENDER_VIEW_HOST_MANAGER_H_ |
OLD | NEW |