mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2025-06-05 21:39:12 +02:00
Persist visited link status (issue #287)
This commit is contained in:
3
cef.gyp
3
cef.gyp
@@ -894,6 +894,9 @@
|
|||||||
'<(DEPTH)/components/components.gyp:update_client',
|
'<(DEPTH)/components/components.gyp:update_client',
|
||||||
'<(DEPTH)/components/components.gyp:user_prefs',
|
'<(DEPTH)/components/components.gyp:user_prefs',
|
||||||
'<(DEPTH)/components/components.gyp:version_info',
|
'<(DEPTH)/components/components.gyp:version_info',
|
||||||
|
'<(DEPTH)/components/components.gyp:visitedlink_browser',
|
||||||
|
'<(DEPTH)/components/components.gyp:visitedlink_common',
|
||||||
|
'<(DEPTH)/components/components.gyp:visitedlink_renderer',
|
||||||
'<(DEPTH)/components/components.gyp:web_cache_renderer',
|
'<(DEPTH)/components/components.gyp:web_cache_renderer',
|
||||||
'<(DEPTH)/components/url_formatter/url_formatter.gyp:url_formatter',
|
'<(DEPTH)/components/url_formatter/url_formatter.gyp:url_formatter',
|
||||||
'<(DEPTH)/content/content.gyp:content_app_both',
|
'<(DEPTH)/content/content.gyp:content_app_both',
|
||||||
|
@@ -152,6 +152,10 @@ class CefBrowserContext
|
|||||||
// Settings for plugins and extensions.
|
// Settings for plugins and extensions.
|
||||||
virtual HostContentSettingsMap* GetHostContentSettingsMap() = 0;
|
virtual HostContentSettingsMap* GetHostContentSettingsMap() = 0;
|
||||||
|
|
||||||
|
// Called from CefBrowserHostImpl::DidNavigateAnyFrame to update the table of
|
||||||
|
// visited links.
|
||||||
|
virtual void AddVisitedURLs(const std::vector<GURL>& urls) = 0;
|
||||||
|
|
||||||
CefResourceContext* resource_context() const {
|
CefResourceContext* resource_context() const {
|
||||||
return resource_context_.get();
|
return resource_context_.get();
|
||||||
}
|
}
|
||||||
|
@@ -17,6 +17,7 @@
|
|||||||
#include "libcef/common/extensions/extensions_util.h"
|
#include "libcef/common/extensions/extensions_util.h"
|
||||||
|
|
||||||
#include "base/command_line.h"
|
#include "base/command_line.h"
|
||||||
|
#include "base/containers/scoped_ptr_map.h"
|
||||||
#include "base/files/file_util.h"
|
#include "base/files/file_util.h"
|
||||||
#include "base/lazy_instance.h"
|
#include "base/lazy_instance.h"
|
||||||
#include "base/logging.h"
|
#include "base/logging.h"
|
||||||
@@ -29,6 +30,8 @@
|
|||||||
#include "components/content_settings/core/browser/host_content_settings_map.h"
|
#include "components/content_settings/core/browser/host_content_settings_map.h"
|
||||||
#include "components/guest_view/browser/guest_view_manager.h"
|
#include "components/guest_view/browser/guest_view_manager.h"
|
||||||
#include "components/ui/zoom/zoom_event_manager.h"
|
#include "components/ui/zoom/zoom_event_manager.h"
|
||||||
|
#include "components/visitedlink/browser/visitedlink_event_listener.h"
|
||||||
|
#include "components/visitedlink/browser/visitedlink_master.h"
|
||||||
#include "content/public/browser/download_manager.h"
|
#include "content/public/browser/download_manager.h"
|
||||||
#include "content/public/browser/browser_thread.h"
|
#include "content/public/browser/browser_thread.h"
|
||||||
#include "content/public/browser/storage_partition.h"
|
#include "content/public/browser/storage_partition.h"
|
||||||
@@ -128,6 +131,67 @@ base::LazyInstance<ImplManager> g_manager = LAZY_INSTANCE_INITIALIZER;
|
|||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
|
// Creates and manages VisitedLinkEventListener objects for each
|
||||||
|
// CefBrowserContext sharing the same VisitedLinkMaster.
|
||||||
|
class CefVisitedLinkListener : public visitedlink::VisitedLinkMaster::Listener {
|
||||||
|
public:
|
||||||
|
CefVisitedLinkListener()
|
||||||
|
: master_(nullptr) {
|
||||||
|
}
|
||||||
|
|
||||||
|
void set_master(visitedlink::VisitedLinkMaster* master) {
|
||||||
|
DCHECK(!master_);
|
||||||
|
master_ = master;
|
||||||
|
}
|
||||||
|
|
||||||
|
void CreateListenerForContext(const CefBrowserContext* context) {
|
||||||
|
CEF_REQUIRE_UIT();
|
||||||
|
scoped_ptr<visitedlink::VisitedLinkEventListener> listener(
|
||||||
|
new visitedlink::VisitedLinkEventListener(
|
||||||
|
master_, const_cast<CefBrowserContext*>(context)));
|
||||||
|
listener_map_.insert(context, listener.Pass());
|
||||||
|
}
|
||||||
|
|
||||||
|
void RemoveListenerForContext(const CefBrowserContext* context) {
|
||||||
|
CEF_REQUIRE_UIT();
|
||||||
|
listener_map_.erase(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
// visitedlink::VisitedLinkMaster::Listener methods.
|
||||||
|
|
||||||
|
void NewTable(base::SharedMemory* shared_memory) override {
|
||||||
|
CEF_REQUIRE_UIT();
|
||||||
|
ListenerMap::const_iterator it = listener_map_.begin();
|
||||||
|
for (; it != listener_map_.end(); ++it)
|
||||||
|
it->second->NewTable(shared_memory);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Add(visitedlink::VisitedLinkCommon::Fingerprint fingerprint) override {
|
||||||
|
CEF_REQUIRE_UIT();
|
||||||
|
ListenerMap::const_iterator it = listener_map_.begin();
|
||||||
|
for (; it != listener_map_.end(); ++it)
|
||||||
|
it->second->Add(fingerprint);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Reset() override {
|
||||||
|
CEF_REQUIRE_UIT();
|
||||||
|
ListenerMap::const_iterator it = listener_map_.begin();
|
||||||
|
for (; it != listener_map_.end(); ++it)
|
||||||
|
it->second->Reset();
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
visitedlink::VisitedLinkMaster* master_;
|
||||||
|
|
||||||
|
// Map of CefBrowserContext to the associated VisitedLinkEventListener.
|
||||||
|
typedef base::ScopedPtrMap<
|
||||||
|
const CefBrowserContext*,
|
||||||
|
scoped_ptr<visitedlink::VisitedLinkEventListener> > ListenerMap;
|
||||||
|
ListenerMap listener_map_;
|
||||||
|
|
||||||
|
DISALLOW_COPY_AND_ASSIGN(CefVisitedLinkListener);
|
||||||
|
};
|
||||||
|
|
||||||
CefBrowserContextImpl::CefBrowserContextImpl(
|
CefBrowserContextImpl::CefBrowserContextImpl(
|
||||||
const CefRequestContextSettings& settings)
|
const CefRequestContextSettings& settings)
|
||||||
: settings_(settings) {
|
: settings_(settings) {
|
||||||
@@ -182,6 +246,19 @@ void CefBrowserContextImpl::Initialize() {
|
|||||||
pref_path = cache_path_.AppendASCII(browser_prefs::kUserPrefsFileName);
|
pref_path = cache_path_.AppendASCII(browser_prefs::kUserPrefsFileName);
|
||||||
pref_service_ = browser_prefs::CreatePrefService(pref_path);
|
pref_service_ = browser_prefs::CreatePrefService(pref_path);
|
||||||
|
|
||||||
|
// Initialize visited links management.
|
||||||
|
base::FilePath visited_link_path;
|
||||||
|
if (!cache_path_.empty())
|
||||||
|
visited_link_path = cache_path_.Append(FILE_PATH_LITERAL("Visited Links"));
|
||||||
|
visitedlink_listener_ = new CefVisitedLinkListener;
|
||||||
|
visitedlink_master_.reset(
|
||||||
|
new visitedlink::VisitedLinkMaster(visitedlink_listener_, this,
|
||||||
|
!visited_link_path.empty(), false,
|
||||||
|
visited_link_path, 0));
|
||||||
|
visitedlink_listener_->set_master(visitedlink_master_.get());
|
||||||
|
visitedlink_listener_->CreateListenerForContext(this);
|
||||||
|
visitedlink_master_->Init();
|
||||||
|
|
||||||
CefBrowserContext::Initialize();
|
CefBrowserContext::Initialize();
|
||||||
|
|
||||||
// Initialize proxy configuration tracker.
|
// Initialize proxy configuration tracker.
|
||||||
@@ -201,10 +278,15 @@ void CefBrowserContextImpl::AddProxy(const CefBrowserContextProxy* proxy) {
|
|||||||
CEF_REQUIRE_UIT();
|
CEF_REQUIRE_UIT();
|
||||||
DCHECK(!HasProxy(proxy));
|
DCHECK(!HasProxy(proxy));
|
||||||
proxy_list_.push_back(proxy);
|
proxy_list_.push_back(proxy);
|
||||||
|
|
||||||
|
visitedlink_listener_->CreateListenerForContext(proxy);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CefBrowserContextImpl::RemoveProxy(const CefBrowserContextProxy* proxy) {
|
void CefBrowserContextImpl::RemoveProxy(const CefBrowserContextProxy* proxy) {
|
||||||
CEF_REQUIRE_UIT();
|
CEF_REQUIRE_UIT();
|
||||||
|
|
||||||
|
visitedlink_listener_->RemoveListenerForContext(proxy);
|
||||||
|
|
||||||
bool found = false;
|
bool found = false;
|
||||||
ProxyList::iterator it = proxy_list_.begin();
|
ProxyList::iterator it = proxy_list_.begin();
|
||||||
for (; it != proxy_list_.end(); ++it) {
|
for (; it != proxy_list_.end(); ++it) {
|
||||||
@@ -405,3 +487,13 @@ HostContentSettingsMap* CefBrowserContextImpl::GetHostContentSettingsMap() {
|
|||||||
}
|
}
|
||||||
return host_content_settings_map_.get();
|
return host_content_settings_map_.get();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CefBrowserContextImpl::AddVisitedURLs(const std::vector<GURL>& urls) {
|
||||||
|
visitedlink_master_->AddURLs(urls);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CefBrowserContextImpl::RebuildTable(
|
||||||
|
const scoped_refptr<URLEnumerator>& enumerator) {
|
||||||
|
// Called when visited links will not or cannot be loaded from disk.
|
||||||
|
enumerator->OnComplete(true);
|
||||||
|
}
|
||||||
|
@@ -14,16 +14,23 @@
|
|||||||
#include "base/memory/ref_counted.h"
|
#include "base/memory/ref_counted.h"
|
||||||
#include "base/memory/scoped_ptr.h"
|
#include "base/memory/scoped_ptr.h"
|
||||||
#include "components/proxy_config/pref_proxy_config_tracker.h"
|
#include "components/proxy_config/pref_proxy_config_tracker.h"
|
||||||
|
#include "components/visitedlink/browser/visitedlink_delegate.h"
|
||||||
|
|
||||||
class CefBrowserContextProxy;
|
class CefBrowserContextProxy;
|
||||||
class CefDownloadManagerDelegate;
|
class CefDownloadManagerDelegate;
|
||||||
class CefSSLHostStateDelegate;
|
class CefSSLHostStateDelegate;
|
||||||
|
class CefVisitedLinkListener;
|
||||||
|
|
||||||
|
namespace visitedlink {
|
||||||
|
class VisitedLinkMaster;
|
||||||
|
}
|
||||||
|
|
||||||
// Isolated BrowserContext implementation. Life span is controlled by
|
// Isolated BrowserContext implementation. Life span is controlled by
|
||||||
// CefRequestContextImpl and (for the main context) CefBrowserMainParts. Only
|
// CefRequestContextImpl and (for the main context) CefBrowserMainParts. Only
|
||||||
// accessed on the UI thread unless otherwise indicated. See browser_context.h
|
// accessed on the UI thread unless otherwise indicated. See browser_context.h
|
||||||
// for an object relationship diagram.
|
// for an object relationship diagram.
|
||||||
class CefBrowserContextImpl : public CefBrowserContext {
|
class CefBrowserContextImpl : public CefBrowserContext,
|
||||||
|
public visitedlink::VisitedLinkDelegate {
|
||||||
public:
|
public:
|
||||||
explicit CefBrowserContextImpl(const CefRequestContextSettings& settings);
|
explicit CefBrowserContextImpl(const CefRequestContextSettings& settings);
|
||||||
|
|
||||||
@@ -87,6 +94,10 @@ class CefBrowserContextImpl : public CefBrowserContext {
|
|||||||
content::URLRequestInterceptorScopedVector request_interceptors)
|
content::URLRequestInterceptorScopedVector request_interceptors)
|
||||||
override;
|
override;
|
||||||
HostContentSettingsMap* GetHostContentSettingsMap() override;
|
HostContentSettingsMap* GetHostContentSettingsMap() override;
|
||||||
|
void AddVisitedURLs(const std::vector<GURL>& urls) override;
|
||||||
|
|
||||||
|
// visitedlink::VisitedLinkDelegate methods.
|
||||||
|
void RebuildTable(const scoped_refptr<URLEnumerator>& enumerator) override;
|
||||||
|
|
||||||
// Guaranteed to exist once this object has been initialized.
|
// Guaranteed to exist once this object has been initialized.
|
||||||
scoped_refptr<CefURLRequestContextGetterImpl> request_context() const {
|
scoped_refptr<CefURLRequestContextGetterImpl> request_context() const {
|
||||||
@@ -117,6 +128,9 @@ class CefBrowserContextImpl : public CefBrowserContext {
|
|||||||
scoped_ptr<content::PermissionManager> permission_manager_;
|
scoped_ptr<content::PermissionManager> permission_manager_;
|
||||||
scoped_ptr<CefSSLHostStateDelegate> ssl_host_state_delegate_;
|
scoped_ptr<CefSSLHostStateDelegate> ssl_host_state_delegate_;
|
||||||
scoped_refptr<HostContentSettingsMap> host_content_settings_map_;
|
scoped_refptr<HostContentSettingsMap> host_content_settings_map_;
|
||||||
|
scoped_ptr<visitedlink::VisitedLinkMaster> visitedlink_master_;
|
||||||
|
// |visitedlink_listener_| is owned by visitedlink_master_.
|
||||||
|
CefVisitedLinkListener* visitedlink_listener_;
|
||||||
|
|
||||||
DISALLOW_COPY_AND_ASSIGN(CefBrowserContextImpl);
|
DISALLOW_COPY_AND_ASSIGN(CefBrowserContextImpl);
|
||||||
};
|
};
|
||||||
|
@@ -12,6 +12,7 @@
|
|||||||
#include "base/logging.h"
|
#include "base/logging.h"
|
||||||
#include "chrome/browser/font_family_cache.h"
|
#include "chrome/browser/font_family_cache.h"
|
||||||
#include "components/guest_view/common/guest_view_constants.h"
|
#include "components/guest_view/common/guest_view_constants.h"
|
||||||
|
#include "components/visitedlink/browser/visitedlink_master.h"
|
||||||
#include "content/browser/streams/stream_context.h"
|
#include "content/browser/streams/stream_context.h"
|
||||||
#include "content/public/browser/storage_partition.h"
|
#include "content/public/browser/storage_partition.h"
|
||||||
|
|
||||||
@@ -191,3 +192,7 @@ net::URLRequestContextGetter*
|
|||||||
HostContentSettingsMap* CefBrowserContextProxy::GetHostContentSettingsMap() {
|
HostContentSettingsMap* CefBrowserContextProxy::GetHostContentSettingsMap() {
|
||||||
return parent_->GetHostContentSettingsMap();
|
return parent_->GetHostContentSettingsMap();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CefBrowserContextProxy::AddVisitedURLs(const std::vector<GURL>& urls) {
|
||||||
|
parent_->AddVisitedURLs(urls);
|
||||||
|
}
|
||||||
|
@@ -69,6 +69,7 @@ class CefBrowserContextProxy : public CefBrowserContext {
|
|||||||
content::URLRequestInterceptorScopedVector request_interceptors)
|
content::URLRequestInterceptorScopedVector request_interceptors)
|
||||||
override;
|
override;
|
||||||
HostContentSettingsMap* GetHostContentSettingsMap() override;
|
HostContentSettingsMap* GetHostContentSettingsMap() override;
|
||||||
|
void AddVisitedURLs(const std::vector<GURL>& urls) override;
|
||||||
|
|
||||||
scoped_refptr<CefBrowserContextImpl> parent() const {
|
scoped_refptr<CefBrowserContextImpl> parent() const {
|
||||||
return parent_;
|
return parent_;
|
||||||
|
@@ -2783,6 +2783,21 @@ void CefBrowserHostImpl::FrameDeleted(
|
|||||||
focused_frame_id_ = CefFrameHostImpl::kInvalidFrameId;
|
focused_frame_id_ = CefFrameHostImpl::kInvalidFrameId;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CefBrowserHostImpl::DidNavigateAnyFrame(
|
||||||
|
content::RenderFrameHost* render_frame_host,
|
||||||
|
const content::LoadCommittedDetails& details,
|
||||||
|
const content::FrameNavigateParams& params) {
|
||||||
|
if (!web_contents())
|
||||||
|
return;
|
||||||
|
|
||||||
|
scoped_refptr<CefBrowserContext> context =
|
||||||
|
static_cast<CefBrowserContext*>(web_contents()->GetBrowserContext());
|
||||||
|
if (!context.get())
|
||||||
|
return;
|
||||||
|
|
||||||
|
context->AddVisitedURLs(params.redirects);
|
||||||
|
}
|
||||||
|
|
||||||
void CefBrowserHostImpl::TitleWasSet(content::NavigationEntry* entry,
|
void CefBrowserHostImpl::TitleWasSet(content::NavigationEntry* entry,
|
||||||
bool explicit_set) {
|
bool explicit_set) {
|
||||||
// |entry| may be NULL if a popup is created via window.open and never
|
// |entry| may be NULL if a popup is created via window.open and never
|
||||||
|
@@ -473,6 +473,10 @@ class CefBrowserHostImpl : public CefBrowserHost,
|
|||||||
bool was_ignored_by_handler) override;
|
bool was_ignored_by_handler) override;
|
||||||
void FrameDeleted(
|
void FrameDeleted(
|
||||||
content::RenderFrameHost* render_frame_host) override;
|
content::RenderFrameHost* render_frame_host) override;
|
||||||
|
void DidNavigateAnyFrame(
|
||||||
|
content::RenderFrameHost* render_frame_host,
|
||||||
|
const content::LoadCommittedDetails& details,
|
||||||
|
const content::FrameNavigateParams& params) override;
|
||||||
void TitleWasSet(content::NavigationEntry* entry, bool explicit_set) override;
|
void TitleWasSet(content::NavigationEntry* entry, bool explicit_set) override;
|
||||||
void PluginCrashed(const base::FilePath& plugin_path,
|
void PluginCrashed(const base::FilePath& plugin_path,
|
||||||
base::ProcessId plugin_pid) override;
|
base::ProcessId plugin_pid) override;
|
||||||
|
@@ -47,6 +47,7 @@
|
|||||||
#include "components/content_settings/core/common/content_settings_types.h"
|
#include "components/content_settings/core/common/content_settings_types.h"
|
||||||
#include "components/nacl/common/nacl_constants.h"
|
#include "components/nacl/common/nacl_constants.h"
|
||||||
#include "components/printing/renderer/print_web_view_helper.h"
|
#include "components/printing/renderer/print_web_view_helper.h"
|
||||||
|
#include "components/visitedlink/renderer/visitedlink_slave.h"
|
||||||
#include "components/web_cache/renderer/web_cache_render_process_observer.h"
|
#include "components/web_cache/renderer/web_cache_render_process_observer.h"
|
||||||
#include "content/child/worker_task_runner.h"
|
#include "content/child/worker_task_runner.h"
|
||||||
#include "content/common/frame_messages.h"
|
#include "content/common/frame_messages.h"
|
||||||
@@ -427,6 +428,9 @@ void CefContentRendererClient::RenderThreadStarted() {
|
|||||||
thread->AddObserver(spellcheck_.get());
|
thread->AddObserver(spellcheck_.get());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
visited_link_slave_.reset(new visitedlink::VisitedLinkSlave());
|
||||||
|
thread->AddObserver(visited_link_slave_.get());
|
||||||
|
|
||||||
if (content::RenderProcessHost::run_renderer_in_process()) {
|
if (content::RenderProcessHost::run_renderer_in_process()) {
|
||||||
// When running in single-process mode register as a destruction observer
|
// When running in single-process mode register as a destruction observer
|
||||||
// on the render thread's MessageLoop.
|
// on the render thread's MessageLoop.
|
||||||
@@ -712,6 +716,15 @@ bool CefContentRendererClient::WillSendRequest(
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
unsigned long long CefContentRendererClient::VisitedLinkHash(
|
||||||
|
const char* canonical_url, size_t length) {
|
||||||
|
return visited_link_slave_->ComputeURLFingerprint(canonical_url, length);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool CefContentRendererClient::IsLinkVisited(unsigned long long link_hash) {
|
||||||
|
return visited_link_slave_->IsVisited(link_hash);
|
||||||
|
}
|
||||||
|
|
||||||
content::BrowserPluginDelegate*
|
content::BrowserPluginDelegate*
|
||||||
CefContentRendererClient::CreateBrowserPluginDelegate(
|
CefContentRendererClient::CreateBrowserPluginDelegate(
|
||||||
content::RenderFrame* render_frame,
|
content::RenderFrame* render_frame,
|
||||||
|
@@ -29,6 +29,10 @@ class ExtensionsRendererClient;
|
|||||||
class ResourceRequestPolicy;
|
class ResourceRequestPolicy;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
namespace visitedlink {
|
||||||
|
class VisitedLinkSlave;
|
||||||
|
}
|
||||||
|
|
||||||
namespace web_cache {
|
namespace web_cache {
|
||||||
class WebCacheRenderProcessObserver;
|
class WebCacheRenderProcessObserver;
|
||||||
}
|
}
|
||||||
@@ -108,6 +112,9 @@ class CefContentRendererClient : public content::ContentRendererClient,
|
|||||||
const GURL& url,
|
const GURL& url,
|
||||||
const GURL& first_party_for_cookies,
|
const GURL& first_party_for_cookies,
|
||||||
GURL* new_url) override;
|
GURL* new_url) override;
|
||||||
|
unsigned long long VisitedLinkHash(const char* canonical_url,
|
||||||
|
size_t length) override;
|
||||||
|
bool IsLinkVisited(unsigned long long link_hash) override;
|
||||||
content::BrowserPluginDelegate* CreateBrowserPluginDelegate(
|
content::BrowserPluginDelegate* CreateBrowserPluginDelegate(
|
||||||
content::RenderFrame* render_frame,
|
content::RenderFrame* render_frame,
|
||||||
const std::string& mime_type,
|
const std::string& mime_type,
|
||||||
@@ -137,6 +144,7 @@ class CefContentRendererClient : public content::ContentRendererClient,
|
|||||||
scoped_ptr<CefRenderProcessObserver> observer_;
|
scoped_ptr<CefRenderProcessObserver> observer_;
|
||||||
scoped_ptr<web_cache::WebCacheRenderProcessObserver> web_cache_observer_;
|
scoped_ptr<web_cache::WebCacheRenderProcessObserver> web_cache_observer_;
|
||||||
scoped_ptr<SpellCheck> spellcheck_;
|
scoped_ptr<SpellCheck> spellcheck_;
|
||||||
|
scoped_ptr<visitedlink::VisitedLinkSlave> visited_link_slave_;
|
||||||
|
|
||||||
// Map of RenderView pointers to CefBrowserImpl references.
|
// Map of RenderView pointers to CefBrowserImpl references.
|
||||||
typedef std::map<content::RenderView*, CefRefPtr<CefBrowserImpl> > BrowserMap;
|
typedef std::map<content::RenderView*, CefRefPtr<CefBrowserImpl> > BrowserMap;
|
||||||
|
@@ -49,6 +49,8 @@ RootWindowManager::RootWindowManager(bool terminate_when_all_windows_closed)
|
|||||||
DCHECK(command_line.get());
|
DCHECK(command_line.get());
|
||||||
request_context_per_browser_ =
|
request_context_per_browser_ =
|
||||||
command_line->HasSwitch(switches::kRequestContextPerBrowser);
|
command_line->HasSwitch(switches::kRequestContextPerBrowser);
|
||||||
|
request_context_shared_cache_ =
|
||||||
|
command_line->HasSwitch(switches::kRequestContextSharedCache);
|
||||||
}
|
}
|
||||||
|
|
||||||
RootWindowManager::~RootWindowManager() {
|
RootWindowManager::~RootWindowManager() {
|
||||||
@@ -147,13 +149,20 @@ CefRefPtr<CefRequestContext> RootWindowManager::GetRequestContext(
|
|||||||
CefRefPtr<CefCommandLine> command_line =
|
CefRefPtr<CefCommandLine> command_line =
|
||||||
CefCommandLine::GetGlobalCommandLine();
|
CefCommandLine::GetGlobalCommandLine();
|
||||||
if (command_line->HasSwitch(switches::kCachePath)) {
|
if (command_line->HasSwitch(switches::kCachePath)) {
|
||||||
// If a global cache path value is specified then give each browser a
|
if (request_context_shared_cache_) {
|
||||||
// unique cache path.
|
// Give each browser the same cache path. The resulting context objects
|
||||||
|
// will share the same storage internally.
|
||||||
|
CefString(&settings.cache_path) =
|
||||||
|
command_line->GetSwitchValue(switches::kCachePath);
|
||||||
|
} else {
|
||||||
|
// Give each browser a unique cache path. This will create completely
|
||||||
|
// isolated context objects.
|
||||||
std::stringstream ss;
|
std::stringstream ss;
|
||||||
ss << command_line->GetSwitchValue(switches::kCachePath).ToString() <<
|
ss << command_line->GetSwitchValue(switches::kCachePath).ToString() <<
|
||||||
time(NULL);
|
time(NULL);
|
||||||
CefString(&settings.cache_path) = ss.str();
|
CefString(&settings.cache_path) = ss.str();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return CefRequestContext::CreateContext(settings,
|
return CefRequestContext::CreateContext(settings,
|
||||||
new ClientRequestContextHandler);
|
new ClientRequestContextHandler);
|
||||||
|
@@ -72,6 +72,7 @@ class RootWindowManager : public RootWindow::Delegate {
|
|||||||
|
|
||||||
const bool terminate_when_all_windows_closed_;
|
const bool terminate_when_all_windows_closed_;
|
||||||
bool request_context_per_browser_;
|
bool request_context_per_browser_;
|
||||||
|
bool request_context_shared_cache_;
|
||||||
|
|
||||||
// Existing root windows. Only accessed on the main thread.
|
// Existing root windows. Only accessed on the main thread.
|
||||||
typedef std::set<scoped_refptr<RootWindow> > RootWindowSet;
|
typedef std::set<scoped_refptr<RootWindow> > RootWindowSet;
|
||||||
|
@@ -26,6 +26,7 @@ const char kTransparentPaintingEnabled[] = "transparent-painting-enabled";
|
|||||||
const char kShowUpdateRect[] = "show-update-rect";
|
const char kShowUpdateRect[] = "show-update-rect";
|
||||||
const char kMouseCursorChangeDisabled[] = "mouse-cursor-change-disabled";
|
const char kMouseCursorChangeDisabled[] = "mouse-cursor-change-disabled";
|
||||||
const char kRequestContextPerBrowser[] = "request-context-per-browser";
|
const char kRequestContextPerBrowser[] = "request-context-per-browser";
|
||||||
|
const char kRequestContextSharedCache[] = "request-context-shared-cache";
|
||||||
const char kBackgroundColor[] = "background-color";
|
const char kBackgroundColor[] = "background-color";
|
||||||
const char kEnableGPU[] = "enable-gpu";
|
const char kEnableGPU[] = "enable-gpu";
|
||||||
const char kFilterURL[] = "filter-url";
|
const char kFilterURL[] = "filter-url";
|
||||||
|
@@ -20,6 +20,7 @@ extern const char kTransparentPaintingEnabled[];
|
|||||||
extern const char kShowUpdateRect[];
|
extern const char kShowUpdateRect[];
|
||||||
extern const char kMouseCursorChangeDisabled[];
|
extern const char kMouseCursorChangeDisabled[];
|
||||||
extern const char kRequestContextPerBrowser[];
|
extern const char kRequestContextPerBrowser[];
|
||||||
|
extern const char kRequestContextSharedCache[];
|
||||||
extern const char kBackgroundColor[];
|
extern const char kBackgroundColor[];
|
||||||
extern const char kEnableGPU[];
|
extern const char kEnableGPU[];
|
||||||
extern const char kFilterURL[];
|
extern const char kFilterURL[];
|
||||||
|
Reference in New Issue
Block a user