mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2024-12-13 18:16:20 +01:00
241941a44a
This change moves the SendProcessMessage method from CefBrowser to CefFrame and adds CefBrowser parameters to OnProcessMessageReceived and OnDraggableRegionsChanged. The internal implementation has changed as follows: - Frame IDs are now a 64-bit combination of the 32-bit render_process_id and render_routing_id values that uniquely identify a RenderFrameHost (RFH). - CefFrameHostImpl objects are now managed by CefBrowserInfo with life span tied to RFH expectations. Specifically, a CefFrameHostImpl object representing a sub-frame will be created when a RenderFrame is created in the renderer process and detached when the associated RenderFrame is deleted or the renderer process in which it runs has died. - The CefFrameHostImpl object representing the main frame will always be valid but the underlying RFH (and associated frame ID) may change over time as a result of cross-origin navigations. Despite these changes calling LoadURL on the main frame object in the browser process will always navigate as expected. - Speculative RFHs, which may be created as a result of a cross-origin navigation and discarded if that navigation is not committed, are now handled correctly (e.g. ignored in most cases until they're committed). - It is less likely, but still possible, to receive a CefFrame object with an invalid frame ID (ID < 0). This can happen in cases where a RFH has not yet been created for a sub-frame. For example, when OnBeforeBrowse is called before initiating navigation in a previously nonexisting sub-frame. To test: All tests pass with NetworkService enabled and disabled.
71 lines
2.7 KiB
C++
71 lines
2.7 KiB
C++
// Copyright (c) 2015 The Chromium Embedded Framework Authors. All rights
|
|
// reserved. Use of this source code is governed by a BSD-style license that
|
|
// can be found in the LICENSE file.
|
|
|
|
#ifndef CEF_LIBCEF_BROWSER_EXTENSIONS_BROWSER_EXTENSIONS_UTIL_H_
|
|
#define CEF_LIBCEF_BROWSER_EXTENSIONS_BROWSER_EXTENSIONS_UTIL_H_
|
|
|
|
#include <vector>
|
|
|
|
#include "libcef/browser/browser_host_impl.h"
|
|
|
|
#include "url/gurl.h"
|
|
|
|
namespace content {
|
|
class BrowserContext;
|
|
class RenderViewHost;
|
|
class WebContents;
|
|
} // namespace content
|
|
|
|
namespace extensions {
|
|
|
|
class Extension;
|
|
|
|
// Returns the full-page guest WebContents for the specified |owner|, if any.
|
|
content::WebContents* GetFullPageGuestForOwnerContents(
|
|
content::WebContents* owner);
|
|
|
|
// Populates |guests| with all guest WebContents with the specified |owner|.
|
|
void GetAllGuestsForOwnerContents(content::WebContents* owner,
|
|
std::vector<content::WebContents*>* guests);
|
|
|
|
// Returns the WebContents that owns the specified |guest|, if any.
|
|
content::WebContents* GetOwnerForGuestContents(content::WebContents* guest);
|
|
|
|
// Returns the CefBrowserHostImpl that owns the host identified by the specified
|
|
// routing IDs, if any. |is_guest_view| will be set to true if the IDs
|
|
// match a guest view associated with the returned browser instead of the
|
|
// browser itself.
|
|
CefRefPtr<CefBrowserHostImpl> GetOwnerBrowserForFrameRoute(
|
|
int render_process_id,
|
|
int render_routing_id,
|
|
bool* is_guest_view);
|
|
|
|
// Returns the CefBrowserHostImpl that owns the specified |host|, if any.
|
|
// |is_guest_view| will be set to true if the host matches a guest view
|
|
// associated with the returned browser instead of the browser itself.
|
|
// TODO(cef): Delete the RVH variant once the remaining use case
|
|
// (via CefContentBrowserClient::OverrideWebkitPrefs) has been removed.
|
|
CefRefPtr<CefBrowserHostImpl> GetOwnerBrowserForHost(
|
|
content::RenderViewHost* host,
|
|
bool* is_guest_view);
|
|
CefRefPtr<CefBrowserHostImpl> GetOwnerBrowserForHost(
|
|
content::RenderFrameHost* host,
|
|
bool* is_guest_view);
|
|
|
|
// Returns the browser matching |tab_id| and |browser_context|. Returns false if
|
|
// |tab_id| is < 0 or a matching browser cannot be found within
|
|
// |browser_context|. Similar in concept to ExtensionTabUtil::GetTabById.
|
|
CefRefPtr<CefBrowserHostImpl> GetBrowserForTabId(
|
|
int tab_id,
|
|
content::BrowserContext* browser_context);
|
|
|
|
// Returns the extension associated with |url| in |profile|. Returns nullptr
|
|
// if the extension does not exist.
|
|
const Extension* GetExtensionForUrl(content::BrowserContext* browser_context,
|
|
const GURL& url);
|
|
|
|
} // namespace extensions
|
|
|
|
#endif // CEF_LIBCEF_BROWSER_EXTENSIONS_BROWSER_EXTENSIONS_UTIL_H_
|