mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2025-01-19 05:04:08 +01:00
38d8acfa18
The Browser object represents the top-level Chrome browser window. One or more tabs (WebContents) are then owned by the Browser object via TabStripModel. A new Browser object can be created programmatically using "new Browser" or Browser::Create, or as a result of user action such as dragging a tab out of an existing window. New or existing tabs can also be added to an already existing Browser object. The Browser object acts as the WebContentsDelegate for all attached tabs. CEF integration requires WebContentsDelegate callbacks and notification of tab attach/detach. To support this integration we add a cef::BrowserDelegate (ChromeBrowserDelegate) member that is created in the Browser constructor and receives delegation for the Browser callbacks. ChromeBrowserDelegate creates a new ChromeBrowserHostImpl when a tab is added to a Browser for the first time, and that ChromeBrowserHostImpl continues to exist until the tab's WebContents is destroyed. The associated WebContents object does not change, but the Browser object will change when the tab is dragged between windows. CEF callback logic is shared between the chrome and alloy runtimes where possible. This shared logic has been extracted from CefBrowserHostImpl to create new CefBrowserHostBase and CefBrowserContentsDelegate classes. The CefBrowserHostImpl class is now only used with the alloy runtime and will be renamed to AlloyBrowserHostImpl in a future commit.
209 lines
7.9 KiB
C++
209 lines
7.9 KiB
C++
// Copyright (c) 2012 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_BROWSER_INFO_H_
|
|
#define CEF_LIBCEF_BROWSER_BROWSER_INFO_H_
|
|
#pragma once
|
|
|
|
#include <set>
|
|
#include <unordered_map>
|
|
|
|
#include "include/internal/cef_ptr.h"
|
|
#include "libcef/common/values_impl.h"
|
|
|
|
#include "base/callback.h"
|
|
#include "base/containers/unique_ptr_adapters.h"
|
|
#include "base/memory/ref_counted.h"
|
|
#include "base/memory/weak_ptr.h"
|
|
#include "base/synchronization/lock.h"
|
|
#include "base/values.h"
|
|
|
|
namespace content {
|
|
class RenderFrameHost;
|
|
}
|
|
|
|
class CefBrowserHostBase;
|
|
class CefFrameHostImpl;
|
|
|
|
// CefBrowserInfo is used to associate a browser ID and render view/process
|
|
// IDs with a particular CefBrowserHostBase. Render view/process IDs may change
|
|
// during the lifetime of a single CefBrowserHostBase.
|
|
//
|
|
// CefBrowserInfo objects are managed by CefBrowserInfoManager and should not be
|
|
// created directly.
|
|
class CefBrowserInfo : public base::RefCountedThreadSafe<CefBrowserInfo> {
|
|
public:
|
|
CefBrowserInfo(int browser_id,
|
|
bool is_popup,
|
|
bool is_windowless,
|
|
CefRefPtr<CefDictionaryValue> extra_info);
|
|
|
|
int browser_id() const { return browser_id_; }
|
|
bool is_popup() const { return is_popup_; }
|
|
bool is_windowless() const { return is_windowless_; }
|
|
CefRefPtr<CefDictionaryValue> extra_info() const { return extra_info_; }
|
|
|
|
// May return NULL if the browser has not yet been created or if the browser
|
|
// has been destroyed.
|
|
CefRefPtr<CefBrowserHostBase> browser() const;
|
|
|
|
// Set or clear the browser. Called from CefBrowserHostBase InitializeBrowser
|
|
// (to set) and DestroyBrowser (to clear).
|
|
void SetBrowser(CefRefPtr<CefBrowserHostBase> browser);
|
|
|
|
// Ensure that a frame record exists for |host|. Called for the main frame
|
|
// when the RenderView is created, or for a sub-frame when the associated
|
|
// RenderFrame is created in the renderer process.
|
|
// Called from CefBrowserContentsDelegate::RenderFrameCreated (is_guest_view =
|
|
// false) or CefMimeHandlerViewGuestDelegate::OnGuestAttached (is_guest_view =
|
|
// true).
|
|
void MaybeCreateFrame(content::RenderFrameHost* host, bool is_guest_view);
|
|
|
|
// Remove the frame record for |host|. Called for the main frame when the
|
|
// RenderView is destroyed, or for a sub-frame when the associated RenderFrame
|
|
// is destroyed in the renderer process.
|
|
// Called from CefBrowserContentsDelegate::RenderFrameDeleted or
|
|
// CefMimeHandlerViewGuestDelegate::OnGuestDetached.
|
|
void RemoveFrame(content::RenderFrameHost* host);
|
|
|
|
// Returns the main frame object. This object will remain valid until the
|
|
// browser is destroyed even though the indentifier may change with cross-
|
|
// origin navigations. Furthermore, calling LoadURL on this object will always
|
|
// behave as expected because the call is routed through the browser's
|
|
// NavigationController.
|
|
CefRefPtr<CefFrameHostImpl> GetMainFrame();
|
|
|
|
// Creates a temporary sub-frame object for situations during navigation or
|
|
// resource loading where a RFH does not yet exist. If |parent_frame_id|
|
|
// is invalid the current main frame will be specified as the parent.
|
|
// Temporary frame objects are not tracked but will be implicitly detached
|
|
// on browser destruction.
|
|
CefRefPtr<CefFrameHostImpl> CreateTempSubFrame(int64_t parent_frame_id);
|
|
|
|
// Returns the frame object matching the specified host or nullptr if no match
|
|
// is found. Nullptr will also be returned if a guest view match is found
|
|
// because we don't create frame objects for guest views. If |is_guest_view|
|
|
// is non-nullptr it will be set to true in this case. Must be called on the
|
|
// UI thread.
|
|
CefRefPtr<CefFrameHostImpl> GetFrameForHost(
|
|
const content::RenderFrameHost* host,
|
|
bool* is_guest_view = nullptr) const;
|
|
|
|
// Returns the frame object matching the specified IDs or nullptr if no match
|
|
// is found. Nullptr will also be returned if a guest view match is found
|
|
// because we don't create frame objects for guest views. If |is_guest_view|
|
|
// is non-nullptr it will be set to true in this case. Safe to call from any
|
|
// thread.
|
|
CefRefPtr<CefFrameHostImpl> GetFrameForRoute(
|
|
int32_t render_process_id,
|
|
int32_t render_routing_id,
|
|
bool* is_guest_view = nullptr) const;
|
|
|
|
// Returns the frame object matching the specified ID or nullptr if no match
|
|
// is found. Nullptr will also be returned if a guest view match is found
|
|
// because we don't create frame objects for guest views. If |is_guest_view|
|
|
// is non-nullptr it will be set to true in this case. Safe to call from any
|
|
// thread.
|
|
CefRefPtr<CefFrameHostImpl> GetFrameForId(
|
|
int64_t frame_id,
|
|
bool* is_guest_view = nullptr) const;
|
|
|
|
// Returns the frame object matching the specified ID or nullptr if no match
|
|
// is found. Nullptr will also be returned if a guest view match is found
|
|
// because we don't create frame objects for guest views. If |is_guest_view|
|
|
// is non-nullptr it will be set to true in this case. Safe to call from any
|
|
// thread.
|
|
CefRefPtr<CefFrameHostImpl> GetFrameForFrameTreeNode(
|
|
int frame_tree_node_id,
|
|
bool* is_guest_view = nullptr) const;
|
|
|
|
// Returns all non-speculative frame objects that currently exist. Guest views
|
|
// will be excluded because they don't have a frame object. Safe to call from
|
|
// any thread.
|
|
typedef std::set<CefRefPtr<CefFrameHostImpl>> FrameHostList;
|
|
FrameHostList GetAllFrames() const;
|
|
|
|
class NavigationLock final : public base::RefCounted<NavigationLock> {
|
|
private:
|
|
friend class CefBrowserInfo;
|
|
friend class base::RefCounted<NavigationLock>;
|
|
|
|
NavigationLock();
|
|
~NavigationLock();
|
|
|
|
base::OnceClosure pending_action_;
|
|
base::WeakPtrFactory<NavigationLock> weak_ptr_factory_;
|
|
};
|
|
|
|
// Block navigation actions on NavigationLock life span. Must be called on the
|
|
// UI thread.
|
|
scoped_refptr<NavigationLock> CreateNavigationLock();
|
|
|
|
// Returns true if navigation actions are currently blocked. If this method
|
|
// returns true the most recent |pending_action| will be executed on the UI
|
|
// thread once the navigation lock is released. Must be called on the UI
|
|
// thread.
|
|
bool IsNavigationLocked(base::OnceClosure pending_action);
|
|
|
|
private:
|
|
friend class base::RefCountedThreadSafe<CefBrowserInfo>;
|
|
|
|
virtual ~CefBrowserInfo();
|
|
|
|
struct FrameInfo {
|
|
~FrameInfo();
|
|
|
|
content::RenderFrameHost* host_;
|
|
int64_t frame_id_; // Combination of render_process_id + render_routing_id.
|
|
int frame_tree_node_id_;
|
|
bool is_guest_view_;
|
|
bool is_main_frame_;
|
|
bool is_speculative_;
|
|
CefRefPtr<CefFrameHostImpl> frame_;
|
|
};
|
|
|
|
void MaybeUpdateFrameTreeNodeIdMap(FrameInfo* info);
|
|
|
|
CefRefPtr<CefFrameHostImpl> GetFrameForFrameTreeNodeInternal(
|
|
int frame_tree_node_id,
|
|
bool* is_guest_view = nullptr) const;
|
|
|
|
void RemoveAllFrames();
|
|
|
|
int browser_id_;
|
|
bool is_popup_;
|
|
bool is_windowless_;
|
|
CefRefPtr<CefDictionaryValue> extra_info_;
|
|
|
|
// Navigation will be blocked while |navigation_lock_| exists.
|
|
// Only accessed on the UI thread.
|
|
base::WeakPtr<NavigationLock> navigation_lock_;
|
|
|
|
mutable base::Lock lock_;
|
|
|
|
// The below members must be protected by |lock_|.
|
|
|
|
CefRefPtr<CefBrowserHostBase> browser_;
|
|
|
|
// Owner of FrameInfo structs.
|
|
typedef std::set<std::unique_ptr<FrameInfo>, base::UniquePtrComparator>
|
|
FrameInfoSet;
|
|
FrameInfoSet frame_info_set_;
|
|
|
|
// Map a frame ID (e.g. MakeFrameId(process_id, routing_id)) to one frame.
|
|
typedef std::unordered_map<int64_t, FrameInfo*> FrameIDMap;
|
|
FrameIDMap frame_id_map_;
|
|
|
|
// Map a frame_tree_node_id to one frame.
|
|
typedef std::unordered_map<int, FrameInfo*> FrameTreeNodeIDMap;
|
|
FrameTreeNodeIDMap frame_tree_node_id_map_;
|
|
|
|
// The current main frame.
|
|
CefRefPtr<CefFrameHostImpl> main_frame_;
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(CefBrowserInfo);
|
|
};
|
|
|
|
#endif // CEF_LIBCEF_BROWSER_BROWSER_INFO_H_
|