mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2025-06-05 21:39:12 +02:00
Rename CEF1 files from /trunk to /trunk/cef1 (issue #564).
git-svn-id: https://chromiumembedded.googlecode.com/svn/trunk@570 5089003a-bbd8-11dd-ad1f-f1f9622dbc98
This commit is contained in:
220
cef1/libcef/cef_process_ui_thread.cc
Normal file
220
cef1/libcef/cef_process_ui_thread.cc
Normal file
@ -0,0 +1,220 @@
|
||||
// Copyright (c) 2010 The Chromium Embedded Framework Authors.
|
||||
// Portions copyright (c) 2010 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/cef_process_ui_thread.h"
|
||||
|
||||
#include <string>
|
||||
|
||||
#include "include/cef_version.h"
|
||||
#include "libcef/browser_webkit_glue.h"
|
||||
#include "libcef/browser_webkit_init.h"
|
||||
#include "libcef/cef_context.h"
|
||||
|
||||
#include "base/bind.h"
|
||||
#include "base/command_line.h"
|
||||
#include "base/i18n/icu_util.h"
|
||||
#include "base/metrics/stats_table.h"
|
||||
#include "base/rand_util.h"
|
||||
#include "base/string_number_conversions.h"
|
||||
#include "base/stringprintf.h"
|
||||
#include "build/build_config.h"
|
||||
#include "net/base/net_module.h"
|
||||
#include "third_party/WebKit/Source/WebKit/chromium/public/WebNetworkStateNotifier.h"
|
||||
#include "third_party/WebKit/Source/WebKit/chromium/public/WebScriptController.h"
|
||||
#include "ui/base/ui_base_paths.h"
|
||||
#include "ui/gfx/gl/gl_implementation.h"
|
||||
#include "webkit/glue/user_agent.h"
|
||||
#include "webkit/glue/webkit_glue.h"
|
||||
#include "webkit/plugins/npapi/plugin_list.h"
|
||||
|
||||
#if defined(OS_WIN)
|
||||
#include <commctrl.h> // NOLINT(build/include_order)
|
||||
#include <Objbase.h> // NOLINT(build/include_order)
|
||||
#endif
|
||||
|
||||
namespace {
|
||||
|
||||
static const char* kStatsFilePrefix = "libcef_";
|
||||
static int kStatsFileThreads = 20;
|
||||
static int kStatsFileCounters = 200;
|
||||
|
||||
base::StringPiece ResourceProvider(int resource_id) {
|
||||
return _Context->GetDataResource(resource_id);
|
||||
}
|
||||
|
||||
} // namespace
|
||||
|
||||
CefProcessUIThread::CefProcessUIThread()
|
||||
: CefThread(CefThread::UI), statstable_(NULL), webkit_init_(NULL) {}
|
||||
|
||||
CefProcessUIThread::CefProcessUIThread(MessageLoop* message_loop)
|
||||
: CefThread(CefThread::UI, message_loop), statstable_(NULL),
|
||||
webkit_init_(NULL) {}
|
||||
|
||||
CefProcessUIThread::~CefProcessUIThread() {
|
||||
// We cannot rely on our base class to stop the thread since we want our
|
||||
// CleanUp function to run.
|
||||
Stop();
|
||||
}
|
||||
|
||||
void CefProcessUIThread::Init() {
|
||||
// Initialize the global CommandLine object.
|
||||
CommandLine::Init(0, NULL);
|
||||
|
||||
const CefSettings& settings = _Context->settings();
|
||||
|
||||
// Initialize logging.
|
||||
logging::LoggingDestination logging_dest;
|
||||
if (settings.log_severity == LOGSEVERITY_DISABLE) {
|
||||
logging_dest = logging::LOG_NONE;
|
||||
} else {
|
||||
#if defined(OS_WIN)
|
||||
logging_dest = logging::LOG_ONLY_TO_FILE;
|
||||
#else
|
||||
logging_dest = logging::LOG_TO_BOTH_FILE_AND_SYSTEM_DEBUG_LOG;
|
||||
#endif
|
||||
logging::SetMinLogLevel(settings.log_severity);
|
||||
}
|
||||
|
||||
FilePath log_file = FilePath(CefString(&settings.log_file));
|
||||
logging::InitLogging(log_file.value().c_str(), logging_dest,
|
||||
logging::DONT_LOCK_LOG_FILE, logging::APPEND_TO_OLD_LOG_FILE,
|
||||
logging::DISABLE_DCHECK_FOR_NON_OFFICIAL_RELEASE_BUILDS);
|
||||
|
||||
// Load ICU data tables.
|
||||
bool ret = icu_util::Initialize();
|
||||
if (!ret) {
|
||||
#if defined(OS_WIN)
|
||||
MessageBox(NULL, L"Failed to load the required icudt library",
|
||||
L"CEF Initialization Error", MB_ICONERROR | MB_OK);
|
||||
#endif
|
||||
return;
|
||||
}
|
||||
|
||||
// Provides path resolution required for locating locale pack files.
|
||||
ui::RegisterPathProvider();
|
||||
|
||||
_Context->InitializeResourceBundle();
|
||||
|
||||
PlatformInit();
|
||||
|
||||
// Initialize WebKit.
|
||||
webkit_init_ = new BrowserWebKitInit();
|
||||
|
||||
// Initialize WebKit encodings
|
||||
webkit_glue::InitializeTextEncoding();
|
||||
|
||||
// Config the network module so it has access to a limited set of resources.
|
||||
net::NetModule::SetResourceProvider(ResourceProvider);
|
||||
|
||||
// Load and initialize the stats table. Attempt to construct a somewhat
|
||||
// unique name to isolate separate instances from each other.
|
||||
statstable_ = new base::StatsTable(
|
||||
kStatsFilePrefix + base::Uint64ToString(base::RandUint64()),
|
||||
kStatsFileThreads,
|
||||
kStatsFileCounters);
|
||||
base::StatsTable::set_current(statstable_);
|
||||
|
||||
if (settings.javascript_flags.length > 0) {
|
||||
// Pass the JavaScript flags to V8.
|
||||
webkit_glue::SetJavaScriptFlags(CefString(&settings.javascript_flags));
|
||||
}
|
||||
|
||||
#if defined(OS_WIN)
|
||||
if (settings.graphics_implementation == ANGLE_IN_PROCESS ||
|
||||
settings.graphics_implementation == ANGLE_IN_PROCESS_COMMAND_BUFFER) {
|
||||
gfx::InitializeGLBindings(gfx::kGLImplementationEGLGLES2);
|
||||
} else {
|
||||
gfx::InitializeGLBindings(gfx::kGLImplementationDesktopGL);
|
||||
}
|
||||
#else
|
||||
gfx::InitializeGLBindings(gfx::kGLImplementationDesktopGL);
|
||||
#endif
|
||||
|
||||
// Set storage quota limits.
|
||||
if (settings.local_storage_quota != 0)
|
||||
DOMStorageContext::set_local_storage_quota(settings.local_storage_quota);
|
||||
if (settings.session_storage_quota != 0) {
|
||||
DOMStorageContext::set_session_storage_quota(
|
||||
settings.session_storage_quota);
|
||||
}
|
||||
|
||||
// Create the storage context object.
|
||||
_Context->set_storage_context(new DOMStorageContext(_Context->cache_path()));
|
||||
|
||||
if (settings.user_agent.length > 0) {
|
||||
webkit_glue::SetUserAgent(CefString(&settings.user_agent), false);
|
||||
} else {
|
||||
std::string product_version;
|
||||
|
||||
if (settings.product_version.length > 0) {
|
||||
product_version = CefString(&settings.product_version).ToString();
|
||||
} else {
|
||||
product_version = base::StringPrintf("Chrome/%d.%d.%d.%d",
|
||||
CHROME_VERSION_MAJOR, CHROME_VERSION_MINOR, CHROME_VERSION_BUILD,
|
||||
CHROME_VERSION_PATCH);
|
||||
}
|
||||
|
||||
webkit_glue::SetUserAgent(
|
||||
webkit_glue::BuildUserAgentFromProduct(product_version), false);
|
||||
}
|
||||
|
||||
if (settings.extra_plugin_paths) {
|
||||
cef_string_t str;
|
||||
memset(&str, 0, sizeof(str));
|
||||
|
||||
FilePath path;
|
||||
int size = cef_string_list_size(settings.extra_plugin_paths);
|
||||
for (int i = 0; i < size; ++i) {
|
||||
if (!cef_string_list_value(settings.extra_plugin_paths, i, &str))
|
||||
continue;
|
||||
path = FilePath(CefString(&str));
|
||||
webkit::npapi::PluginList::Singleton()->AddExtraPluginPath(path);
|
||||
}
|
||||
}
|
||||
|
||||
// Create a network change notifier before starting the IO & File threads.
|
||||
network_change_notifier_.reset(net::NetworkChangeNotifier::Create());
|
||||
|
||||
// Add a listener for OnOnlineStateChanged to notify WebKit of changes.
|
||||
net::NetworkChangeNotifier::AddOnlineStateObserver(this);
|
||||
|
||||
// Initialize WebKit with the current state.
|
||||
WebKit::WebNetworkStateNotifier::setOnLine(
|
||||
!net::NetworkChangeNotifier::IsOffline());
|
||||
}
|
||||
|
||||
void CefProcessUIThread::CleanUp() {
|
||||
// Flush any remaining messages. This ensures that any accumulated
|
||||
// Task objects get destroyed before we exit, which avoids noise in
|
||||
// purify leak-test results.
|
||||
MessageLoop::current()->RunAllPending();
|
||||
|
||||
// Destroy the storage context object.
|
||||
_Context->set_storage_context(NULL);
|
||||
|
||||
// Tear down the shared StatsTable.
|
||||
base::StatsTable::set_current(NULL);
|
||||
delete statstable_;
|
||||
statstable_ = NULL;
|
||||
|
||||
// Shut down WebKit.
|
||||
delete webkit_init_;
|
||||
webkit_init_ = NULL;
|
||||
|
||||
// Release the network change notifier after all other threads end.
|
||||
net::NetworkChangeNotifier::RemoveOnlineStateObserver(this);
|
||||
network_change_notifier_.reset();
|
||||
|
||||
PlatformCleanUp();
|
||||
|
||||
_Context->CleanupResourceBundle();
|
||||
}
|
||||
|
||||
void CefProcessUIThread::OnOnlineStateChanged(bool online) {
|
||||
DCHECK(CefThread::CurrentlyOn(CefThread::UI));
|
||||
WebKit::WebNetworkStateNotifier::setOnLine(online);
|
||||
}
|
||||
|
Reference in New Issue
Block a user