mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2025-02-21 22:47:42 +01:00
This includes: - Red underline of misspelled words in html text areas. - Right-click context menu options to correct the misspelled word. - New CefBrowser::ReplaceMisspelling method for accepting a word replacement. - Methods added to CefContextMenuParams for retrieving spelling-related information. - Uses the unified text checker when auto-correct is not enabled to match Google Chrome behavior. - On Windows and Linux a hunspell dictionary file will be downloaded to the "<cache_path>/Dictionaries" directory as needed, or used from the <cache_path> directory if the file already exists there. The dictionary file will be downloaded from http://cache.pack.google.com/edgedl/chrome/dict/<LANG>-3-0.bdic where <LANG> is the language abbreviation. - On OS X the spell checking implementation will use the system NSSpellChecker implementation. The following command-line flags have been added: --disable-spell-checking => Disable spell-checking support (no red underline, no dictionary file download, etc). --enable-spelling-auto-correct => Automatically correct common misspellings while typing (like 'omre' to 'more' on Windows/Linux or 'ehlo' to 'helo' on OS X). --enable-spelling-service => Enable use of the remote Google spelling service (this requires Google API keys). --override-spell-check-lang=<LANG> => Use the specified dictionary language <LANG> instead of the language specified in the locales.pak file. To see the default/supported dictionary languages: https://code.google.com/p/chromium/codesearch#search/&q=IDS_SPELLCHECK_DICTIONARY%20xtb&sq=package:chromium git-svn-id: https://chromiumembedded.googlecode.com/svn/trunk@1859 5089003a-bbd8-11dd-ad1f-f1f9622dbc98
158 lines
4.8 KiB
C++
158 lines
4.8 KiB
C++
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#include "libcef/browser/browser_context_proxy.h"
|
|
|
|
#include "libcef/browser/content_browser_client.h"
|
|
#include "libcef/browser/download_manager_delegate.h"
|
|
#include "libcef/browser/thread_util.h"
|
|
#include "libcef/browser/url_request_context_getter.h"
|
|
#include "libcef/browser/url_request_context_getter_proxy.h"
|
|
|
|
#include "base/bind.h"
|
|
#include "base/logging.h"
|
|
#include "base/threading/thread.h"
|
|
#include "components/keyed_service/content/browser_context_dependency_manager.h"
|
|
#include "content/public/browser/browser_thread.h"
|
|
#include "content/public/browser/resource_context.h"
|
|
#include "content/public/browser/storage_partition.h"
|
|
|
|
using content::BrowserThread;
|
|
|
|
class CefBrowserContextProxy::CefResourceContext :
|
|
public content::ResourceContext {
|
|
public:
|
|
CefResourceContext() : getter_(NULL) {}
|
|
virtual ~CefResourceContext() {}
|
|
|
|
// ResourceContext implementation:
|
|
virtual net::HostResolver* GetHostResolver() OVERRIDE {
|
|
CHECK(getter_);
|
|
return getter_->GetHostResolver();
|
|
}
|
|
virtual net::URLRequestContext* GetRequestContext() OVERRIDE {
|
|
CHECK(getter_);
|
|
return getter_->GetURLRequestContext();
|
|
}
|
|
|
|
void set_url_request_context_getter(CefURLRequestContextGetterProxy* getter) {
|
|
getter_ = getter;
|
|
}
|
|
|
|
private:
|
|
CefURLRequestContextGetterProxy* getter_;
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(CefResourceContext);
|
|
};
|
|
|
|
CefBrowserContextProxy::CefBrowserContextProxy(
|
|
CefRefPtr<CefRequestContextHandler> handler,
|
|
CefBrowserContext* parent)
|
|
: refct_(0),
|
|
handler_(handler),
|
|
parent_(parent),
|
|
resource_context_(new CefResourceContext) {
|
|
}
|
|
|
|
CefBrowserContextProxy::~CefBrowserContextProxy() {
|
|
if (resource_context_.get()) {
|
|
BrowserThread::DeleteSoon(
|
|
BrowserThread::IO, FROM_HERE, resource_context_.release());
|
|
}
|
|
|
|
// Remove any BrowserContextKeyedServiceFactory associations.
|
|
BrowserContextDependencyManager::GetInstance()->DestroyBrowserContextServices(
|
|
this);
|
|
}
|
|
|
|
base::FilePath CefBrowserContextProxy::GetPath() const {
|
|
return parent_->GetPath();
|
|
}
|
|
|
|
bool CefBrowserContextProxy::IsOffTheRecord() const {
|
|
return parent_->IsOffTheRecord();
|
|
}
|
|
|
|
content::DownloadManagerDelegate*
|
|
CefBrowserContextProxy::GetDownloadManagerDelegate() {
|
|
DCHECK(!download_manager_delegate_.get());
|
|
|
|
content::DownloadManager* manager = BrowserContext::GetDownloadManager(this);
|
|
download_manager_delegate_.reset(new CefDownloadManagerDelegate(manager));
|
|
return download_manager_delegate_.get();
|
|
}
|
|
|
|
net::URLRequestContextGetter* CefBrowserContextProxy::GetRequestContext() {
|
|
CEF_REQUIRE_UIT();
|
|
return GetDefaultStoragePartition(this)->GetURLRequestContext();
|
|
}
|
|
|
|
net::URLRequestContextGetter*
|
|
CefBrowserContextProxy::GetRequestContextForRenderProcess(
|
|
int renderer_child_id) {
|
|
return GetRequestContext();
|
|
}
|
|
|
|
net::URLRequestContextGetter*
|
|
CefBrowserContextProxy::GetMediaRequestContext() {
|
|
return GetRequestContext();
|
|
}
|
|
|
|
net::URLRequestContextGetter*
|
|
CefBrowserContextProxy::GetMediaRequestContextForRenderProcess(
|
|
int renderer_child_id) {
|
|
return GetRequestContext();
|
|
}
|
|
|
|
net::URLRequestContextGetter*
|
|
CefBrowserContextProxy::GetMediaRequestContextForStoragePartition(
|
|
const base::FilePath& partition_path,
|
|
bool in_memory) {
|
|
return GetRequestContext();
|
|
}
|
|
|
|
content::ResourceContext* CefBrowserContextProxy::GetResourceContext() {
|
|
return resource_context_.get();
|
|
}
|
|
|
|
content::BrowserPluginGuestManager* CefBrowserContextProxy::GetGuestManager() {
|
|
return parent_->GetGuestManager();
|
|
}
|
|
|
|
storage::SpecialStoragePolicy*
|
|
CefBrowserContextProxy::GetSpecialStoragePolicy() {
|
|
return parent_->GetSpecialStoragePolicy();
|
|
}
|
|
|
|
content::PushMessagingService*
|
|
CefBrowserContextProxy::GetPushMessagingService() {
|
|
return parent_->GetPushMessagingService();
|
|
}
|
|
|
|
content::SSLHostStateDelegate*
|
|
CefBrowserContextProxy::GetSSLHostStateDelegate() {
|
|
return parent_->GetSSLHostStateDelegate();
|
|
}
|
|
|
|
net::URLRequestContextGetter* CefBrowserContextProxy::CreateRequestContext(
|
|
content::ProtocolHandlerMap* protocol_handlers,
|
|
content::URLRequestInterceptorScopedVector request_interceptors) {
|
|
DCHECK(!url_request_getter_.get());
|
|
url_request_getter_ =
|
|
new CefURLRequestContextGetterProxy(handler_,
|
|
static_cast<CefURLRequestContextGetter*>(
|
|
CefContentBrowserClient::Get()->request_context().get()));
|
|
resource_context_->set_url_request_context_getter(url_request_getter_.get());
|
|
return url_request_getter_.get();
|
|
}
|
|
|
|
net::URLRequestContextGetter*
|
|
CefBrowserContextProxy::CreateRequestContextForStoragePartition(
|
|
const base::FilePath& partition_path,
|
|
bool in_memory,
|
|
content::ProtocolHandlerMap* protocol_handlers,
|
|
content::URLRequestInterceptorScopedVector request_interceptors) {
|
|
return NULL;
|
|
}
|