mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2025-06-05 21:39:12 +02:00
- Update to Chromium revision 69409.
- Add cefclient tests for GPU acceleration. git-svn-id: https://chromiumembedded.googlecode.com/svn/trunk@152 5089003a-bbd8-11dd-ad1f-f1f9622dbc98
This commit is contained in:
@@ -59,3 +59,4 @@ Date | CEF Revision | Chromium Revision
|
|||||||
2010-10-26 | /trunk@127 | /trunk@63876
|
2010-10-26 | /trunk@127 | /trunk@63876
|
||||||
2010-10-28 | /trunk@129 | /trunk@64233
|
2010-10-28 | /trunk@129 | /trunk@64233
|
||||||
2010-11-16 | /trunk@138 | /trunk@66269
|
2010-11-16 | /trunk@138 | /trunk@66269
|
||||||
|
2010-12-16 | /trunk@152 | /trunk@69409
|
||||||
|
@@ -1770,8 +1770,9 @@ public:
|
|||||||
local_storage_disabled = r.local_storage_disabled;
|
local_storage_disabled = r.local_storage_disabled;
|
||||||
databases_disabled = r.databases_disabled;
|
databases_disabled = r.databases_disabled;
|
||||||
application_cache_disabled = r.application_cache_disabled;
|
application_cache_disabled = r.application_cache_disabled;
|
||||||
experimental_webgl_enabled = r.experimental_webgl_enabled;
|
webgl_disabled = r.webgl_disabled;
|
||||||
accelerated_compositing_disabled = r.accelerated_compositing_disabled;
|
accelerated_compositing_disabled = r.accelerated_compositing_disabled;
|
||||||
|
accelerated_layers_disabled = r.accelerated_layers_disabled;
|
||||||
accelerated_2d_canvas_disabled = r.accelerated_2d_canvas_disabled;
|
accelerated_2d_canvas_disabled = r.accelerated_2d_canvas_disabled;
|
||||||
|
|
||||||
return *this;
|
return *this;
|
||||||
|
@@ -200,12 +200,16 @@ typedef struct _cef_browser_settings_t
|
|||||||
// Set to true (1) to disable application cache.
|
// Set to true (1) to disable application cache.
|
||||||
bool application_cache_disabled;
|
bool application_cache_disabled;
|
||||||
|
|
||||||
// Set to true (1) to enable experimental WebGL features.
|
// Set to true (1) to disable WebGL.
|
||||||
bool experimental_webgl_enabled;
|
bool webgl_disabled;
|
||||||
|
|
||||||
// Set to true (1) to disable accelerated compositing.
|
// Set to true (1) to disable accelerated compositing.
|
||||||
bool accelerated_compositing_disabled;
|
bool accelerated_compositing_disabled;
|
||||||
|
|
||||||
|
// Set to true (1) to disable accelerated layers. This affects features like
|
||||||
|
// 3D CSS transforms.
|
||||||
|
bool accelerated_layers_disabled;
|
||||||
|
|
||||||
// Set to true (1) to disable accelerated 2d canvas.
|
// Set to true (1) to disable accelerated 2d canvas.
|
||||||
bool accelerated_2d_canvas_disabled;
|
bool accelerated_2d_canvas_disabled;
|
||||||
} cef_browser_settings_t;
|
} cef_browser_settings_t;
|
||||||
|
@@ -431,7 +431,7 @@ WebApplicationCacheHost* BrowserAppCacheSystem::CreateCacheHostForWebKit(
|
|||||||
}
|
}
|
||||||
|
|
||||||
void BrowserAppCacheSystem::SetExtraRequestBits(
|
void BrowserAppCacheSystem::SetExtraRequestBits(
|
||||||
URLRequest* request, int host_id, ResourceType::Type resource_type) {
|
net::URLRequest* request, int host_id, ResourceType::Type resource_type) {
|
||||||
if (is_initialized()) {
|
if (is_initialized()) {
|
||||||
DCHECK(is_io_thread());
|
DCHECK(is_io_thread());
|
||||||
AppCacheInterceptor::SetExtraRequestInfo(
|
AppCacheInterceptor::SetExtraRequestInfo(
|
||||||
@@ -440,7 +440,7 @@ void BrowserAppCacheSystem::SetExtraRequestBits(
|
|||||||
}
|
}
|
||||||
|
|
||||||
void BrowserAppCacheSystem::GetExtraResponseBits(
|
void BrowserAppCacheSystem::GetExtraResponseBits(
|
||||||
URLRequest* request, int64* cache_id, GURL* manifest_url) {
|
net::URLRequest* request, int64* cache_id, GURL* manifest_url) {
|
||||||
if (is_initialized()) {
|
if (is_initialized()) {
|
||||||
DCHECK(is_io_thread());
|
DCHECK(is_io_thread());
|
||||||
AppCacheInterceptor::GetExtraResponseInfo(
|
AppCacheInterceptor::GetExtraResponseInfo(
|
||||||
|
@@ -20,12 +20,12 @@ class WebApplicationCacheHostClient;
|
|||||||
}
|
}
|
||||||
class BrowserBackendProxy;
|
class BrowserBackendProxy;
|
||||||
class BrowserFrontendProxy;
|
class BrowserFrontendProxy;
|
||||||
class URLRequest;
|
class net::URLRequest;
|
||||||
class URLRequestContext;
|
class URLRequestContext;
|
||||||
|
|
||||||
// A class that composes the constituent parts of an appcache system
|
// A class that composes the constituent parts of an appcache system
|
||||||
// together for use in a single process with two relavant threads,
|
// together for use in a single process with two relavant threads,
|
||||||
// a UI thread on which webkit runs and an IO thread on which URLRequests
|
// a UI thread on which webkit runs and an IO thread on which net::URLRequests
|
||||||
// are handled. This class conspires with BrowserResourceLoaderBridge to
|
// are handled. This class conspires with BrowserResourceLoaderBridge to
|
||||||
// retrieve resources from the appcache.
|
// retrieve resources from the appcache.
|
||||||
class BrowserAppCacheSystem {
|
class BrowserAppCacheSystem {
|
||||||
@@ -63,7 +63,7 @@ class BrowserAppCacheSystem {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Called by BrowserResourceLoaderBridge to hook into resource loads.
|
// Called by BrowserResourceLoaderBridge to hook into resource loads.
|
||||||
static void SetExtraRequestInfo(URLRequest* request,
|
static void SetExtraRequestInfo(net::URLRequest* request,
|
||||||
int host_id,
|
int host_id,
|
||||||
ResourceType::Type resource_type) {
|
ResourceType::Type resource_type) {
|
||||||
if (instance_)
|
if (instance_)
|
||||||
@@ -71,7 +71,7 @@ class BrowserAppCacheSystem {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Called by BrowserResourceLoaderBridge extract extra response bits.
|
// Called by BrowserResourceLoaderBridge extract extra response bits.
|
||||||
static void GetExtraResponseInfo(URLRequest* request,
|
static void GetExtraResponseInfo(net::URLRequest* request,
|
||||||
int64* cache_id,
|
int64* cache_id,
|
||||||
GURL* manifest_url) {
|
GURL* manifest_url) {
|
||||||
if (instance_)
|
if (instance_)
|
||||||
@@ -116,10 +116,10 @@ class BrowserAppCacheSystem {
|
|||||||
void CleanupIOThread();
|
void CleanupIOThread();
|
||||||
WebKit::WebApplicationCacheHost* CreateCacheHostForWebKit(
|
WebKit::WebApplicationCacheHost* CreateCacheHostForWebKit(
|
||||||
WebKit::WebApplicationCacheHostClient* client);
|
WebKit::WebApplicationCacheHostClient* client);
|
||||||
void SetExtraRequestBits(URLRequest* request,
|
void SetExtraRequestBits(net::URLRequest* request,
|
||||||
int host_id,
|
int host_id,
|
||||||
ResourceType::Type resource_type);
|
ResourceType::Type resource_type);
|
||||||
void GetExtraResponseBits(URLRequest* request,
|
void GetExtraResponseBits(net::URLRequest* request,
|
||||||
int64* cache_id,
|
int64* cache_id,
|
||||||
GURL* manifest_url);
|
GURL* manifest_url);
|
||||||
|
|
||||||
|
@@ -6,55 +6,76 @@
|
|||||||
#include "browser_file_writer.h"
|
#include "browser_file_writer.h"
|
||||||
|
|
||||||
#include "base/file_path.h"
|
#include "base/file_path.h"
|
||||||
|
#include "base/message_loop.h"
|
||||||
#include "base/message_loop_proxy.h"
|
#include "base/message_loop_proxy.h"
|
||||||
|
#include "base/scoped_callback_factory.h"
|
||||||
#include "base/time.h"
|
#include "base/time.h"
|
||||||
|
#include "base/utf_string_conversions.h"
|
||||||
|
#include "googleurl/src/gurl.h"
|
||||||
#include "third_party/WebKit/WebKit/chromium/public/WebFileInfo.h"
|
#include "third_party/WebKit/WebKit/chromium/public/WebFileInfo.h"
|
||||||
|
#include "third_party/WebKit/WebKit/chromium/public/WebFileSystemCallbacks.h"
|
||||||
#include "third_party/WebKit/WebKit/chromium/public/WebFileSystemEntry.h"
|
#include "third_party/WebKit/WebKit/chromium/public/WebFileSystemEntry.h"
|
||||||
|
#include "third_party/WebKit/WebKit/chromium/public/WebFrame.h"
|
||||||
|
#include "third_party/WebKit/WebKit/chromium/public/WebSecurityOrigin.h"
|
||||||
#include "third_party/WebKit/WebKit/chromium/public/WebVector.h"
|
#include "third_party/WebKit/WebKit/chromium/public/WebVector.h"
|
||||||
#include "webkit/fileapi/file_system_callback_dispatcher.h"
|
#include "webkit/fileapi/file_system_callback_dispatcher.h"
|
||||||
|
#include "webkit/fileapi/file_system_path_manager.h"
|
||||||
|
#include "webkit/fileapi/file_system_types.h"
|
||||||
|
#include "webkit/fileapi/sandboxed_file_system_context.h"
|
||||||
|
#include "webkit/fileapi/sandboxed_file_system_operation.h"
|
||||||
#include "webkit/glue/webkit_glue.h"
|
#include "webkit/glue/webkit_glue.h"
|
||||||
|
|
||||||
|
using base::WeakPtr;
|
||||||
|
|
||||||
using WebKit::WebFileInfo;
|
using WebKit::WebFileInfo;
|
||||||
|
using WebKit::WebFileSystem;
|
||||||
using WebKit::WebFileSystemCallbacks;
|
using WebKit::WebFileSystemCallbacks;
|
||||||
using WebKit::WebFileSystemEntry;
|
using WebKit::WebFileSystemEntry;
|
||||||
using WebKit::WebFileWriter;
|
using WebKit::WebFileWriter;
|
||||||
using WebKit::WebFileWriterClient;
|
using WebKit::WebFileWriterClient;
|
||||||
|
using WebKit::WebFrame;
|
||||||
|
using WebKit::WebSecurityOrigin;
|
||||||
using WebKit::WebString;
|
using WebKit::WebString;
|
||||||
using WebKit::WebVector;
|
using WebKit::WebVector;
|
||||||
|
|
||||||
|
using fileapi::FileSystemCallbackDispatcher;
|
||||||
|
using fileapi::SandboxedFileSystemContext;
|
||||||
|
using fileapi::SandboxedFileSystemOperation;
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
class BrowserFileSystemCallbackDispatcher
|
class BrowserFileSystemCallbackDispatcher
|
||||||
: public fileapi::FileSystemCallbackDispatcher {
|
: public FileSystemCallbackDispatcher {
|
||||||
public:
|
public:
|
||||||
BrowserFileSystemCallbackDispatcher(
|
BrowserFileSystemCallbackDispatcher(
|
||||||
BrowserFileSystem* file_system,
|
const WeakPtr<BrowserFileSystem>& file_system,
|
||||||
WebFileSystemCallbacks* callbacks)
|
WebFileSystemCallbacks* callbacks)
|
||||||
: file_system_(file_system),
|
: file_system_(file_system),
|
||||||
callbacks_(callbacks),
|
callbacks_(callbacks) {
|
||||||
request_id_(-1) {
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void set_request_id(int request_id) { request_id_ = request_id; }
|
~BrowserFileSystemCallbackDispatcher() {
|
||||||
|
}
|
||||||
|
|
||||||
virtual void DidSucceed() {
|
virtual void DidSucceed() {
|
||||||
|
DCHECK(file_system_);
|
||||||
callbacks_->didSucceed();
|
callbacks_->didSucceed();
|
||||||
file_system_->RemoveCompletedOperation(request_id_);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void DidReadMetadata(const base::PlatformFileInfo& info) {
|
virtual void DidReadMetadata(const base::PlatformFileInfo& info) {
|
||||||
|
DCHECK(file_system_);
|
||||||
WebFileInfo web_file_info;
|
WebFileInfo web_file_info;
|
||||||
web_file_info.length = info.size;
|
web_file_info.length = info.size;
|
||||||
web_file_info.modificationTime = info.last_modified.ToDoubleT();
|
web_file_info.modificationTime = info.last_modified.ToDoubleT();
|
||||||
web_file_info.type = info.is_directory ?
|
web_file_info.type = info.is_directory ?
|
||||||
WebFileInfo::TypeDirectory : WebFileInfo::TypeFile;
|
WebFileInfo::TypeDirectory : WebFileInfo::TypeFile;
|
||||||
callbacks_->didReadMetadata(web_file_info);
|
callbacks_->didReadMetadata(web_file_info);
|
||||||
file_system_->RemoveCompletedOperation(request_id_);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void DidReadDirectory(
|
virtual void DidReadDirectory(
|
||||||
const std::vector<base::FileUtilProxy::Entry>& entries,
|
const std::vector<base::FileUtilProxy::Entry>& entries,
|
||||||
bool has_more) {
|
bool has_more) {
|
||||||
|
DCHECK(file_system_);
|
||||||
std::vector<WebFileSystemEntry> web_entries_vector;
|
std::vector<WebFileSystemEntry> web_entries_vector;
|
||||||
for (std::vector<base::FileUtilProxy::Entry>::const_iterator it =
|
for (std::vector<base::FileUtilProxy::Entry>::const_iterator it =
|
||||||
entries.begin(); it != entries.end(); ++it) {
|
entries.begin(); it != entries.end(); ++it) {
|
||||||
@@ -66,17 +87,22 @@ class BrowserFileSystemCallbackDispatcher
|
|||||||
WebVector<WebKit::WebFileSystemEntry> web_entries =
|
WebVector<WebKit::WebFileSystemEntry> web_entries =
|
||||||
web_entries_vector;
|
web_entries_vector;
|
||||||
callbacks_->didReadDirectory(web_entries, has_more);
|
callbacks_->didReadDirectory(web_entries, has_more);
|
||||||
file_system_->RemoveCompletedOperation(request_id_);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void DidOpenFileSystem(const std::string&, const FilePath&) {
|
virtual void DidOpenFileSystem(
|
||||||
NOTREACHED();
|
const std::string& name, const FilePath& path) {
|
||||||
|
DCHECK(file_system_);
|
||||||
|
if (path.empty())
|
||||||
|
callbacks_->didFail(WebKit::WebFileErrorSecurity);
|
||||||
|
else
|
||||||
|
callbacks_->didOpenFileSystem(
|
||||||
|
UTF8ToUTF16(name), webkit_glue::FilePathToWebString(path));
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void DidFail(base::PlatformFileError error_code) {
|
virtual void DidFail(base::PlatformFileError error_code) {
|
||||||
|
DCHECK(file_system_);
|
||||||
callbacks_->didFail(
|
callbacks_->didFail(
|
||||||
webkit_glue::PlatformFileErrorToWebFileError(error_code));
|
webkit_glue::PlatformFileErrorToWebFileError(error_code));
|
||||||
file_system_->RemoveCompletedOperation(request_id_);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void DidWrite(int64, bool) {
|
virtual void DidWrite(int64, bool) {
|
||||||
@@ -84,18 +110,53 @@ class BrowserFileSystemCallbackDispatcher
|
|||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
BrowserFileSystem* file_system_;
|
WeakPtr<BrowserFileSystem> file_system_;
|
||||||
WebFileSystemCallbacks* callbacks_;
|
WebFileSystemCallbacks* callbacks_;
|
||||||
int request_id_;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|
||||||
|
BrowserFileSystem::BrowserFileSystem() {
|
||||||
|
if (file_system_dir_.CreateUniqueTempDir()) {
|
||||||
|
sandboxed_context_ = new SandboxedFileSystemContext(
|
||||||
|
base::MessageLoopProxy::CreateForCurrentThread(),
|
||||||
|
base::MessageLoopProxy::CreateForCurrentThread(),
|
||||||
|
file_system_dir_.path(),
|
||||||
|
false /* incognito */,
|
||||||
|
true /* allow_file_access */,
|
||||||
|
false /* unlimited_quota */);
|
||||||
|
} else {
|
||||||
|
LOG(WARNING) << "Failed to create a temp dir for the filesystem."
|
||||||
|
"FileSystem feature will be disabled.";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
BrowserFileSystem::~BrowserFileSystem() {
|
BrowserFileSystem::~BrowserFileSystem() {
|
||||||
// Drop all the operations.
|
}
|
||||||
for (OperationsMap::const_iterator iter(&operations_);
|
|
||||||
!iter.IsAtEnd(); iter.Advance())
|
void BrowserFileSystem::OpenFileSystem(
|
||||||
operations_.Remove(iter.GetCurrentKey());
|
WebFrame* frame, WebFileSystem::Type web_filesystem_type,
|
||||||
|
long long, bool create,
|
||||||
|
WebFileSystemCallbacks* callbacks) {
|
||||||
|
if (!frame || !sandboxed_context_.get()) {
|
||||||
|
// The FileSystem temp directory was not initialized successfully.
|
||||||
|
callbacks->didFail(WebKit::WebFileErrorSecurity);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
fileapi::FileSystemType type;
|
||||||
|
if (web_filesystem_type == WebFileSystem::TypeTemporary)
|
||||||
|
type = fileapi::kFileSystemTypeTemporary;
|
||||||
|
else if (web_filesystem_type == WebFileSystem::TypePersistent)
|
||||||
|
type = fileapi::kFileSystemTypePersistent;
|
||||||
|
else {
|
||||||
|
// Unknown type filesystem is requested.
|
||||||
|
callbacks->didFail(WebKit::WebFileErrorSecurity);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
GURL origin_url(frame->securityOrigin().toString());
|
||||||
|
GetNewOperation(callbacks)->OpenFileSystem(origin_url, type, create);
|
||||||
}
|
}
|
||||||
|
|
||||||
void BrowserFileSystem::move(
|
void BrowserFileSystem::move(
|
||||||
@@ -177,18 +238,12 @@ WebFileWriter* BrowserFileSystem::createFileWriter(
|
|||||||
return new BrowserFileWriter(path, client);
|
return new BrowserFileWriter(path, client);
|
||||||
}
|
}
|
||||||
|
|
||||||
fileapi::FileSystemOperation* BrowserFileSystem::GetNewOperation(
|
SandboxedFileSystemOperation* BrowserFileSystem::GetNewOperation(
|
||||||
WebFileSystemCallbacks* callbacks) {
|
WebFileSystemCallbacks* callbacks) {
|
||||||
// This pointer will be owned by |operation|.
|
|
||||||
BrowserFileSystemCallbackDispatcher* dispatcher =
|
BrowserFileSystemCallbackDispatcher* dispatcher =
|
||||||
new BrowserFileSystemCallbackDispatcher(this, callbacks);
|
new BrowserFileSystemCallbackDispatcher(AsWeakPtr(), callbacks);
|
||||||
fileapi::FileSystemOperation* operation = new fileapi::FileSystemOperation(
|
SandboxedFileSystemOperation* operation = new SandboxedFileSystemOperation(
|
||||||
dispatcher, base::MessageLoopProxy::CreateForCurrentThread());
|
dispatcher, base::MessageLoopProxy::CreateForCurrentThread(),
|
||||||
int32 request_id = operations_.Add(operation);
|
sandboxed_context_.get());
|
||||||
dispatcher->set_request_id(request_id);
|
|
||||||
return operation;
|
return operation;
|
||||||
}
|
}
|
||||||
|
|
||||||
void BrowserFileSystem::RemoveCompletedOperation(int request_id) {
|
|
||||||
operations_.Remove(request_id);
|
|
||||||
}
|
|
||||||
|
@@ -8,16 +8,33 @@
|
|||||||
#include <vector>
|
#include <vector>
|
||||||
#include "base/file_util_proxy.h"
|
#include "base/file_util_proxy.h"
|
||||||
#include "base/id_map.h"
|
#include "base/id_map.h"
|
||||||
|
#include "base/scoped_temp_dir.h"
|
||||||
|
#include "base/weak_ptr.h"
|
||||||
#include "third_party/WebKit/WebKit/chromium/public/WebFileSystem.h"
|
#include "third_party/WebKit/WebKit/chromium/public/WebFileSystem.h"
|
||||||
#include "third_party/WebKit/WebKit/chromium/public/WebFileSystemCallbacks.h"
|
#include "webkit/fileapi/file_system_types.h"
|
||||||
#include "webkit/fileapi/file_system_operation.h"
|
|
||||||
|
|
||||||
class BrowserFileSystem : public WebKit::WebFileSystem {
|
namespace WebKit {
|
||||||
|
class WebFileSystemCallbacks;
|
||||||
|
class WebFrame;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace fileapi {
|
||||||
|
class SandboxedFileSystemContext;
|
||||||
|
class SandboxedFileSystemOperation;
|
||||||
|
}
|
||||||
|
|
||||||
|
class BrowserFileSystem
|
||||||
|
: public WebKit::WebFileSystem,
|
||||||
|
public base::SupportsWeakPtr<BrowserFileSystem> {
|
||||||
public:
|
public:
|
||||||
BrowserFileSystem() {}
|
BrowserFileSystem();
|
||||||
virtual ~BrowserFileSystem();
|
virtual ~BrowserFileSystem();
|
||||||
|
|
||||||
void RemoveCompletedOperation(int request_id);
|
void OpenFileSystem(WebKit::WebFrame* frame,
|
||||||
|
WebKit::WebFileSystem::Type type,
|
||||||
|
long long size,
|
||||||
|
bool create,
|
||||||
|
WebKit::WebFileSystemCallbacks* callbacks);
|
||||||
|
|
||||||
// WebKit::WebFileSystem methods.
|
// WebKit::WebFileSystem methods.
|
||||||
virtual void move(const WebKit::WebString& src_path,
|
virtual void move(const WebKit::WebString& src_path,
|
||||||
@@ -49,12 +66,13 @@ class BrowserFileSystem : public WebKit::WebFileSystem {
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
// Helpers.
|
// Helpers.
|
||||||
fileapi::FileSystemOperation* GetNewOperation(
|
fileapi::SandboxedFileSystemOperation* GetNewOperation(
|
||||||
WebKit::WebFileSystemCallbacks* callbacks);
|
WebKit::WebFileSystemCallbacks* callbacks);
|
||||||
|
|
||||||
// Keeps ongoing file system operations.
|
// A temporary directory for FileSystem API.
|
||||||
typedef IDMap<fileapi::FileSystemOperation, IDMapOwnPointer> OperationsMap;
|
ScopedTempDir file_system_dir_;
|
||||||
OperationsMap operations_;
|
|
||||||
|
scoped_refptr<fileapi::SandboxedFileSystemContext> sandboxed_context_;
|
||||||
|
|
||||||
DISALLOW_COPY_AND_ASSIGN(BrowserFileSystem);
|
DISALLOW_COPY_AND_ASSIGN(BrowserFileSystem);
|
||||||
};
|
};
|
||||||
|
@@ -28,7 +28,8 @@ class BrowserFileWriter::IOThreadProxy
|
|||||||
: public base::RefCountedThreadSafe<BrowserFileWriter::IOThreadProxy> {
|
: public base::RefCountedThreadSafe<BrowserFileWriter::IOThreadProxy> {
|
||||||
public:
|
public:
|
||||||
explicit IOThreadProxy(const base::WeakPtr<BrowserFileWriter>& simple_writer)
|
explicit IOThreadProxy(const base::WeakPtr<BrowserFileWriter>& simple_writer)
|
||||||
: simple_writer_(simple_writer) {
|
: simple_writer_(simple_writer),
|
||||||
|
operation_(NULL) {
|
||||||
io_thread_ = CefThread::GetMessageLoopProxyForThread(CefThread::IO);
|
io_thread_ = CefThread::GetMessageLoopProxyForThread(CefThread::IO);
|
||||||
main_thread_ = base::MessageLoopProxy::CreateForCurrentThread();
|
main_thread_ = base::MessageLoopProxy::CreateForCurrentThread();
|
||||||
}
|
}
|
||||||
@@ -42,8 +43,8 @@ class BrowserFileWriter::IOThreadProxy
|
|||||||
this, &IOThreadProxy::Truncate, path, offset));
|
this, &IOThreadProxy::Truncate, path, offset));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
DCHECK(!operation_.get());
|
DCHECK(!operation_);
|
||||||
operation_.reset(GetNewOperation());
|
operation_ = GetNewOperation();
|
||||||
operation_->Truncate(path, offset);
|
operation_->Truncate(path, offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -54,8 +55,8 @@ class BrowserFileWriter::IOThreadProxy
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
DCHECK(request_context_);
|
DCHECK(request_context_);
|
||||||
DCHECK(!operation_.get());
|
DCHECK(!operation_);
|
||||||
operation_.reset(GetNewOperation());
|
operation_ = GetNewOperation();
|
||||||
operation_->Write(request_context_, path, blob_url, offset);
|
operation_->Write(request_context_, path, blob_url, offset);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -65,12 +66,11 @@ class BrowserFileWriter::IOThreadProxy
|
|||||||
this, &IOThreadProxy::Cancel));
|
this, &IOThreadProxy::Cancel));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (!operation_.get()) {
|
if (!operation_) {
|
||||||
DidFail(base::PLATFORM_FILE_ERROR_INVALID_OPERATION);
|
DidFail(base::PLATFORM_FILE_ERROR_INVALID_OPERATION);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
cancel_operation_.reset(GetNewOperation());
|
operation_->Cancel(GetNewOperation());
|
||||||
operation_->Cancel(cancel_operation_.get());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
@@ -80,6 +80,10 @@ class BrowserFileWriter::IOThreadProxy
|
|||||||
explicit CallbackDispatcher(IOThreadProxy* proxy) : proxy_(proxy) {
|
explicit CallbackDispatcher(IOThreadProxy* proxy) : proxy_(proxy) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
~CallbackDispatcher() {
|
||||||
|
proxy_->ClearOperation();
|
||||||
|
}
|
||||||
|
|
||||||
virtual void DidSucceed() {
|
virtual void DidSucceed() {
|
||||||
proxy_->DidSucceed();
|
proxy_->DidSucceed();
|
||||||
}
|
}
|
||||||
@@ -117,7 +121,6 @@ class BrowserFileWriter::IOThreadProxy
|
|||||||
|
|
||||||
void DidSucceed() {
|
void DidSucceed() {
|
||||||
if (!main_thread_->BelongsToCurrentThread()) {
|
if (!main_thread_->BelongsToCurrentThread()) {
|
||||||
operation_.reset();
|
|
||||||
main_thread_->PostTask(FROM_HERE, NewRunnableMethod(
|
main_thread_->PostTask(FROM_HERE, NewRunnableMethod(
|
||||||
this, &IOThreadProxy::DidSucceed));
|
this, &IOThreadProxy::DidSucceed));
|
||||||
return;
|
return;
|
||||||
@@ -128,7 +131,6 @@ class BrowserFileWriter::IOThreadProxy
|
|||||||
|
|
||||||
void DidFail(base::PlatformFileError error_code) {
|
void DidFail(base::PlatformFileError error_code) {
|
||||||
if (!main_thread_->BelongsToCurrentThread()) {
|
if (!main_thread_->BelongsToCurrentThread()) {
|
||||||
operation_.reset();
|
|
||||||
main_thread_->PostTask(FROM_HERE, NewRunnableMethod(
|
main_thread_->PostTask(FROM_HERE, NewRunnableMethod(
|
||||||
this, &IOThreadProxy::DidFail, error_code));
|
this, &IOThreadProxy::DidFail, error_code));
|
||||||
return;
|
return;
|
||||||
@@ -139,8 +141,6 @@ class BrowserFileWriter::IOThreadProxy
|
|||||||
|
|
||||||
void DidWrite(int64 bytes, bool complete) {
|
void DidWrite(int64 bytes, bool complete) {
|
||||||
if (!main_thread_->BelongsToCurrentThread()) {
|
if (!main_thread_->BelongsToCurrentThread()) {
|
||||||
if (complete)
|
|
||||||
operation_.reset();
|
|
||||||
main_thread_->PostTask(FROM_HERE, NewRunnableMethod(
|
main_thread_->PostTask(FROM_HERE, NewRunnableMethod(
|
||||||
this, &IOThreadProxy::DidWrite, bytes, complete));
|
this, &IOThreadProxy::DidWrite, bytes, complete));
|
||||||
return;
|
return;
|
||||||
@@ -149,6 +149,11 @@ class BrowserFileWriter::IOThreadProxy
|
|||||||
simple_writer_->DidWrite(bytes, complete);
|
simple_writer_->DidWrite(bytes, complete);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ClearOperation() {
|
||||||
|
DCHECK(io_thread_->BelongsToCurrentThread());
|
||||||
|
operation_ = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
scoped_refptr<base::MessageLoopProxy> io_thread_;
|
scoped_refptr<base::MessageLoopProxy> io_thread_;
|
||||||
scoped_refptr<base::MessageLoopProxy> main_thread_;
|
scoped_refptr<base::MessageLoopProxy> main_thread_;
|
||||||
|
|
||||||
@@ -156,8 +161,7 @@ class BrowserFileWriter::IOThreadProxy
|
|||||||
base::WeakPtr<BrowserFileWriter> simple_writer_;
|
base::WeakPtr<BrowserFileWriter> simple_writer_;
|
||||||
|
|
||||||
// Only used on the io thread.
|
// Only used on the io thread.
|
||||||
scoped_ptr<FileSystemOperation> operation_;
|
FileSystemOperation* operation_;
|
||||||
scoped_ptr<FileSystemOperation> cancel_operation_;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@@ -101,7 +101,7 @@ void BrowserRequestContext::Init(
|
|||||||
cache_path, 0, BrowserResourceLoaderBridge::GetCacheThread());
|
cache_path, 0, BrowserResourceLoaderBridge::GetCacheThread());
|
||||||
|
|
||||||
net::HttpCache* cache =
|
net::HttpCache* cache =
|
||||||
new net::HttpCache(host_resolver_, NULL, proxy_service_,
|
new net::HttpCache(host_resolver_, NULL, NULL, proxy_service_,
|
||||||
ssl_config_service_, http_auth_handler_factory_, NULL,
|
ssl_config_service_, http_auth_handler_factory_, NULL,
|
||||||
NULL, backend);
|
NULL, backend);
|
||||||
|
|
||||||
|
@@ -4,12 +4,12 @@
|
|||||||
// found in the LICENSE file.
|
// found in the LICENSE file.
|
||||||
//
|
//
|
||||||
// This file contains an implementation of the ResourceLoaderBridge class.
|
// This file contains an implementation of the ResourceLoaderBridge class.
|
||||||
// The class is implemented using URLRequest, meaning it is a "simple" version
|
// The class is implemented using net::URLRequest, meaning it is a "simple" version
|
||||||
// that directly issues requests. The more complicated one used in the
|
// that directly issues requests. The more complicated one used in the
|
||||||
// browser uses IPC.
|
// browser uses IPC.
|
||||||
//
|
//
|
||||||
// Because URLRequest only provides an asynchronous resource loading API, this
|
// Because net::URLRequest only provides an asynchronous resource loading API, this
|
||||||
// file makes use of URLRequest from a background IO thread. Requests for
|
// file makes use of net::URLRequest from a background IO thread. Requests for
|
||||||
// cookies and synchronously loaded resources result in the main thread of the
|
// cookies and synchronously loaded resources result in the main thread of the
|
||||||
// application blocking until the IO thread completes the operation. (See
|
// application blocking until the IO thread completes the operation. (See
|
||||||
// GetCookies and SyncLoad)
|
// GetCookies and SyncLoad)
|
||||||
@@ -17,9 +17,9 @@
|
|||||||
// Main thread IO thread
|
// Main thread IO thread
|
||||||
// ----------- ---------
|
// ----------- ---------
|
||||||
// ResourceLoaderBridge <---o---------> RequestProxy (normal case)
|
// ResourceLoaderBridge <---o---------> RequestProxy (normal case)
|
||||||
// \ -> URLRequest
|
// \ -> net::URLRequest
|
||||||
// o-------> SyncRequestProxy (synchronous case)
|
// o-------> SyncRequestProxy (synchronous case)
|
||||||
// -> URLRequest
|
// -> net::URLRequest
|
||||||
// SetCookie <------------------------> CookieSetter
|
// SetCookie <------------------------> CookieSetter
|
||||||
// -> net_util::SetCookie
|
// -> net_util::SetCookie
|
||||||
// GetCookies <-----------------------> CookieGetter
|
// GetCookies <-----------------------> CookieGetter
|
||||||
@@ -27,7 +27,7 @@
|
|||||||
//
|
//
|
||||||
// NOTE: The implementation in this file may be used to have WebKit fetch
|
// NOTE: The implementation in this file may be used to have WebKit fetch
|
||||||
// resources in-process. For example, it is handy for building a single-
|
// resources in-process. For example, it is handy for building a single-
|
||||||
// process WebKit embedding (e.g., test_shell) that can use URLRequest to
|
// process WebKit embedding (e.g., test_shell) that can use net::URLRequest to
|
||||||
// perform URL loads. See renderer/resource_dispatcher.h for details on an
|
// perform URL loads. See renderer/resource_dispatcher.h for details on an
|
||||||
// alternate implementation that defers fetching to another process.
|
// alternate implementation that defers fetching to another process.
|
||||||
|
|
||||||
@@ -101,9 +101,9 @@ struct RequestParams {
|
|||||||
static const int kUpdateUploadProgressIntervalMsec = 100;
|
static const int kUpdateUploadProgressIntervalMsec = 100;
|
||||||
|
|
||||||
// The RequestProxy does most of its work on the IO thread. The Start and
|
// The RequestProxy does most of its work on the IO thread. The Start and
|
||||||
// Cancel methods are proxied over to the IO thread, where an URLRequest object
|
// Cancel methods are proxied over to the IO thread, where an net::URLRequest object
|
||||||
// is instantiated.
|
// is instantiated.
|
||||||
class RequestProxy : public URLRequest::Delegate,
|
class RequestProxy : public net::URLRequest::Delegate,
|
||||||
public base::RefCountedThreadSafe<RequestProxy> {
|
public base::RefCountedThreadSafe<RequestProxy> {
|
||||||
public:
|
public:
|
||||||
// Takes ownership of the params.
|
// Takes ownership of the params.
|
||||||
@@ -149,7 +149,7 @@ class RequestProxy : public URLRequest::Delegate,
|
|||||||
|
|
||||||
// --------------------------------------------------------------------------
|
// --------------------------------------------------------------------------
|
||||||
// The following methods are called on the owner's thread in response to
|
// The following methods are called on the owner's thread in response to
|
||||||
// various URLRequest callbacks. The event hooks, defined below, trigger
|
// various net::URLRequest callbacks. The event hooks, defined below, trigger
|
||||||
// these methods asynchronously.
|
// these methods asynchronously.
|
||||||
|
|
||||||
void NotifyReceivedRedirect(const GURL& new_url,
|
void NotifyReceivedRedirect(const GURL& new_url,
|
||||||
@@ -360,7 +360,7 @@ class RequestProxy : public URLRequest::Delegate,
|
|||||||
ResolveBlobReferencesInUploadData(params->upload.get());
|
ResolveBlobReferencesInUploadData(params->upload.get());
|
||||||
}
|
}
|
||||||
|
|
||||||
request_.reset(new URLRequest(params->url, this));
|
request_.reset(new net::URLRequest(params->url, this));
|
||||||
request_->set_method(params->method);
|
request_->set_method(params->method);
|
||||||
request_->set_first_party_for_cookies(params->first_party_for_cookies);
|
request_->set_first_party_for_cookies(params->first_party_for_cookies);
|
||||||
request_->set_referrer(params->referrer.spec());
|
request_->set_referrer(params->referrer.spec());
|
||||||
@@ -447,7 +447,7 @@ class RequestProxy : public URLRequest::Delegate,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// --------------------------------------------------------------------------
|
// --------------------------------------------------------------------------
|
||||||
// The following methods are event hooks (corresponding to URLRequest
|
// The following methods are event hooks (corresponding to net::URLRequest
|
||||||
// callbacks) that run on the IO thread. They are designed to be overridden
|
// callbacks) that run on the IO thread. They are designed to be overridden
|
||||||
// by the SyncRequestProxy subclass.
|
// by the SyncRequestProxy subclass.
|
||||||
|
|
||||||
@@ -491,9 +491,9 @@ class RequestProxy : public URLRequest::Delegate,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// --------------------------------------------------------------------------
|
// --------------------------------------------------------------------------
|
||||||
// URLRequest::Delegate implementation:
|
// net::URLRequest::Delegate implementation:
|
||||||
|
|
||||||
virtual void OnReceivedRedirect(URLRequest* request,
|
virtual void OnReceivedRedirect(net::URLRequest* request,
|
||||||
const GURL& new_url,
|
const GURL& new_url,
|
||||||
bool* defer_redirect) {
|
bool* defer_redirect) {
|
||||||
DCHECK(request->status().is_success());
|
DCHECK(request->status().is_success());
|
||||||
@@ -502,7 +502,7 @@ class RequestProxy : public URLRequest::Delegate,
|
|||||||
OnReceivedRedirect(new_url, info, defer_redirect);
|
OnReceivedRedirect(new_url, info, defer_redirect);
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void OnResponseStarted(URLRequest* request) {
|
virtual void OnResponseStarted(net::URLRequest* request) {
|
||||||
if (request->status().is_success()) {
|
if (request->status().is_success()) {
|
||||||
ResourceResponseInfo info;
|
ResourceResponseInfo info;
|
||||||
PopulateResponseInfo(request, &info);
|
PopulateResponseInfo(request, &info);
|
||||||
@@ -513,14 +513,14 @@ class RequestProxy : public URLRequest::Delegate,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void OnSSLCertificateError(URLRequest* request,
|
virtual void OnSSLCertificateError(net::URLRequest* request,
|
||||||
int cert_error,
|
int cert_error,
|
||||||
net::X509Certificate* cert) {
|
net::X509Certificate* cert) {
|
||||||
// Allow all certificate errors.
|
// Allow all certificate errors.
|
||||||
request->ContinueDespiteLastError();
|
request->ContinueDespiteLastError();
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void OnReadCompleted(URLRequest* request, int bytes_read) {
|
virtual void OnReadCompleted(net::URLRequest* request, int bytes_read) {
|
||||||
if (request->status().is_success() && bytes_read > 0) {
|
if (request->status().is_success() && bytes_read > 0) {
|
||||||
OnReceivedData(bytes_read);
|
OnReceivedData(bytes_read);
|
||||||
} else {
|
} else {
|
||||||
@@ -550,7 +550,7 @@ class RequestProxy : public URLRequest::Delegate,
|
|||||||
|
|
||||||
// Called on the IO thread.
|
// Called on the IO thread.
|
||||||
void MaybeUpdateUploadProgress() {
|
void MaybeUpdateUploadProgress() {
|
||||||
// If a redirect is received upload is cancelled in URLRequest, we should
|
// If a redirect is received upload is cancelled in net::URLRequest, we should
|
||||||
// try to stop the |upload_progress_timer_| timer and return.
|
// try to stop the |upload_progress_timer_| timer and return.
|
||||||
if (!request_->has_upload()) {
|
if (!request_->has_upload()) {
|
||||||
if (upload_progress_timer_.IsRunning())
|
if (upload_progress_timer_.IsRunning())
|
||||||
@@ -583,7 +583,7 @@ class RequestProxy : public URLRequest::Delegate,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void PopulateResponseInfo(URLRequest* request,
|
void PopulateResponseInfo(net::URLRequest* request,
|
||||||
ResourceResponseInfo* info) const {
|
ResourceResponseInfo* info) const {
|
||||||
info->request_time = request->request_time();
|
info->request_time = request->request_time();
|
||||||
info->response_time = request->response_time();
|
info->response_time = request->response_time();
|
||||||
@@ -599,7 +599,7 @@ class RequestProxy : public URLRequest::Delegate,
|
|||||||
&info->appcache_manifest_url);
|
&info->appcache_manifest_url);
|
||||||
}
|
}
|
||||||
|
|
||||||
scoped_ptr<URLRequest> request_;
|
scoped_ptr<net::URLRequest> request_;
|
||||||
CefRefPtr<CefStreamReader> resource_stream_;
|
CefRefPtr<CefStreamReader> resource_stream_;
|
||||||
|
|
||||||
// Support for request.download_to_file behavior.
|
// Support for request.download_to_file behavior.
|
||||||
|
@@ -121,9 +121,10 @@ void BrowserToWebSettings(const CefBrowserSettings& cef, WebPreferences& web)
|
|||||||
web.allow_universal_access_from_file_urls =
|
web.allow_universal_access_from_file_urls =
|
||||||
cef.universal_access_from_file_urls_allowed;
|
cef.universal_access_from_file_urls_allowed;
|
||||||
web.allow_file_access_from_file_urls = cef.file_access_from_file_urls_allowed;
|
web.allow_file_access_from_file_urls = cef.file_access_from_file_urls_allowed;
|
||||||
web.experimental_webgl_enabled = cef.experimental_webgl_enabled;
|
web.experimental_webgl_enabled = !cef.webgl_disabled;
|
||||||
web.show_composited_layer_borders = false;
|
web.show_composited_layer_borders = false;
|
||||||
web.accelerated_compositing_enabled = !cef.accelerated_compositing_disabled;
|
web.accelerated_compositing_enabled = !cef.accelerated_compositing_disabled;
|
||||||
|
web.accelerated_layers_enabled = !cef.accelerated_layers_disabled;
|
||||||
web.accelerated_2d_canvas_enabled = !cef.accelerated_2d_canvas_disabled;
|
web.accelerated_2d_canvas_enabled = !cef.accelerated_2d_canvas_disabled;
|
||||||
web.memory_info_enabled = false;
|
web.memory_info_enabled = false;
|
||||||
}
|
}
|
||||||
|
@@ -26,6 +26,7 @@ MSVC_POP_WARNING();
|
|||||||
#include "third_party/WebKit/WebKit/chromium/public/WebFrame.h"
|
#include "third_party/WebKit/WebKit/chromium/public/WebFrame.h"
|
||||||
#include "third_party/WebKit/WebKit/chromium/public/WebString.h"
|
#include "third_party/WebKit/WebKit/chromium/public/WebString.h"
|
||||||
#include "webkit/glue/webkit_glue.h"
|
#include "webkit/glue/webkit_glue.h"
|
||||||
|
#include "webkit/glue/plugins/plugin_list.h"
|
||||||
|
|
||||||
// Generated by GRIT
|
// Generated by GRIT
|
||||||
#include "grit/webkit_resources.h"
|
#include "grit/webkit_resources.h"
|
||||||
@@ -60,6 +61,10 @@ bool GetPluginFinderURL(std::string* plugin_finder_url) {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void GetPlugins(bool refresh, std::vector<WebPluginInfo>* plugins) {
|
||||||
|
NPAPI::PluginList::Singleton()->GetPlugins(refresh, plugins);
|
||||||
|
}
|
||||||
|
|
||||||
bool IsDefaultPluginEnabled() {
|
bool IsDefaultPluginEnabled() {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@@ -17,7 +17,6 @@
|
|||||||
#include "base/path_service.h"
|
#include "base/path_service.h"
|
||||||
#include "grit/webkit_resources.h"
|
#include "grit/webkit_resources.h"
|
||||||
#include "webkit/glue/webkit_glue.h"
|
#include "webkit/glue/webkit_glue.h"
|
||||||
#include "webkit/glue/plugins/plugin_list.h"
|
|
||||||
|
|
||||||
namespace webkit_glue {
|
namespace webkit_glue {
|
||||||
|
|
||||||
@@ -127,10 +126,6 @@ base::StringPiece GetDataResource(int resource_id) {
|
|||||||
return base::StringPiece();
|
return base::StringPiece();
|
||||||
}
|
}
|
||||||
|
|
||||||
void GetPlugins(bool refresh, std::vector<WebPluginInfo>* plugins) {
|
|
||||||
NPAPI::PluginList::Singleton()->GetPlugins(refresh, plugins);
|
|
||||||
}
|
|
||||||
|
|
||||||
void DidLoadPlugin(const std::string& filename) {
|
void DidLoadPlugin(const std::string& filename) {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -25,7 +25,6 @@ MSVC_POP_WARNING();
|
|||||||
#include "third_party/WebKit/WebKit/chromium/public/WebSize.h"
|
#include "third_party/WebKit/WebKit/chromium/public/WebSize.h"
|
||||||
#include "third_party/WebKit/WebKit/chromium/public/WebView.h"
|
#include "third_party/WebKit/WebKit/chromium/public/WebView.h"
|
||||||
#include "webkit/glue/webkit_glue.h"
|
#include "webkit/glue/webkit_glue.h"
|
||||||
#include "webkit/glue/plugins/plugin_list.h"
|
|
||||||
|
|
||||||
using WebKit::WebRect;
|
using WebKit::WebRect;
|
||||||
using WebKit::WebSize;
|
using WebKit::WebSize;
|
||||||
@@ -70,10 +69,6 @@ base::StringPiece GetDataResource(int resource_id) {
|
|||||||
return NetResourceProvider(resource_id);
|
return NetResourceProvider(resource_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
void GetPlugins(bool refresh, std::vector<WebPluginInfo>* plugins) {
|
|
||||||
NPAPI::PluginList::Singleton()->GetPlugins(refresh, plugins);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool EnsureFontLoaded(HFONT font) {
|
bool EnsureFontLoaded(HFONT font) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@@ -232,6 +232,56 @@ class BrowserWebKitInit : public webkit_glue::WebKitClientImpl {
|
|||||||
return WebKit::WebGraphicsContext3D::createDefault();
|
return WebKit::WebGraphicsContext3D::createDefault();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
WebKit::WebString queryLocalizedString(
|
||||||
|
WebKit::WebLocalizedString::Name name) {
|
||||||
|
switch (name) {
|
||||||
|
case WebKit::WebLocalizedString::ValidationValueMissing:
|
||||||
|
case WebKit::WebLocalizedString::ValidationValueMissingForCheckbox:
|
||||||
|
case WebKit::WebLocalizedString::ValidationValueMissingForFile:
|
||||||
|
case WebKit::WebLocalizedString::ValidationValueMissingForMultipleFile:
|
||||||
|
case WebKit::WebLocalizedString::ValidationValueMissingForRadio:
|
||||||
|
case WebKit::WebLocalizedString::ValidationValueMissingForSelect:
|
||||||
|
return ASCIIToUTF16("value missing");
|
||||||
|
case WebKit::WebLocalizedString::ValidationTypeMismatch:
|
||||||
|
case WebKit::WebLocalizedString::ValidationTypeMismatchForEmail:
|
||||||
|
case WebKit::WebLocalizedString::ValidationTypeMismatchForMultipleEmail:
|
||||||
|
case WebKit::WebLocalizedString::ValidationTypeMismatchForURL:
|
||||||
|
return ASCIIToUTF16("type mismatch");
|
||||||
|
case WebKit::WebLocalizedString::ValidationPatternMismatch:
|
||||||
|
return ASCIIToUTF16("pattern mismatch");
|
||||||
|
case WebKit::WebLocalizedString::ValidationTooLong:
|
||||||
|
return ASCIIToUTF16("too long");
|
||||||
|
case WebKit::WebLocalizedString::ValidationRangeUnderflow:
|
||||||
|
return ASCIIToUTF16("range underflow");
|
||||||
|
case WebKit::WebLocalizedString::ValidationRangeOverflow:
|
||||||
|
return ASCIIToUTF16("range overflow");
|
||||||
|
case WebKit::WebLocalizedString::ValidationStepMismatch:
|
||||||
|
return ASCIIToUTF16("step mismatch");
|
||||||
|
default:
|
||||||
|
return WebKitClientImpl::queryLocalizedString(name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
WebKit::WebString queryLocalizedString(
|
||||||
|
WebKit::WebLocalizedString::Name name, const WebKit::WebString& value) {
|
||||||
|
if (name == WebKit::WebLocalizedString::ValidationRangeUnderflow)
|
||||||
|
return ASCIIToUTF16("range underflow");
|
||||||
|
if (name == WebKit::WebLocalizedString::ValidationRangeOverflow)
|
||||||
|
return ASCIIToUTF16("range overflow");
|
||||||
|
return WebKitClientImpl::queryLocalizedString(name, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
WebKit::WebString queryLocalizedString(
|
||||||
|
WebKit::WebLocalizedString::Name name,
|
||||||
|
const WebKit::WebString& value1,
|
||||||
|
const WebKit::WebString& value2) {
|
||||||
|
if (name == WebKit::WebLocalizedString::ValidationTooLong)
|
||||||
|
return ASCIIToUTF16("too long");
|
||||||
|
if (name == WebKit::WebLocalizedString::ValidationStepMismatch)
|
||||||
|
return ASCIIToUTF16("step mismatch");
|
||||||
|
return WebKitClientImpl::queryLocalizedString(name, value1, value2);
|
||||||
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
webkit_glue::SimpleWebMimeRegistryImpl mime_registry_;
|
webkit_glue::SimpleWebMimeRegistryImpl mime_registry_;
|
||||||
webkit_glue::WebClipboardImpl clipboard_;
|
webkit_glue::WebClipboardImpl clipboard_;
|
||||||
|
@@ -9,6 +9,7 @@
|
|||||||
|
|
||||||
#include "browser_webview_delegate.h"
|
#include "browser_webview_delegate.h"
|
||||||
#include "browser_appcache_system.h"
|
#include "browser_appcache_system.h"
|
||||||
|
#include "browser_file_system.h"
|
||||||
#include "browser_impl.h"
|
#include "browser_impl.h"
|
||||||
#include "browser_navigation_controller.h"
|
#include "browser_navigation_controller.h"
|
||||||
#include "browser_web_worker.h"
|
#include "browser_web_worker.h"
|
||||||
@@ -22,6 +23,7 @@
|
|||||||
#include "base/process_util.h"
|
#include "base/process_util.h"
|
||||||
#include "base/string_util.h"
|
#include "base/string_util.h"
|
||||||
#include "gfx/point.h"
|
#include "gfx/point.h"
|
||||||
|
#include "media/base/filter_collection.h"
|
||||||
#include "media/filters/audio_renderer_impl.h"
|
#include "media/filters/audio_renderer_impl.h"
|
||||||
#include "net/base/net_errors.h"
|
#include "net/base/net_errors.h"
|
||||||
#include "third_party/WebKit/WebKit/chromium/public/WebConsoleMessage.h"
|
#include "third_party/WebKit/WebKit/chromium/public/WebConsoleMessage.h"
|
||||||
@@ -553,30 +555,12 @@ WebWorker* BrowserWebViewDelegate::createWorker(
|
|||||||
|
|
||||||
WebMediaPlayer* BrowserWebViewDelegate::createMediaPlayer(
|
WebMediaPlayer* BrowserWebViewDelegate::createMediaPlayer(
|
||||||
WebFrame* frame, WebMediaPlayerClient* client) {
|
WebFrame* frame, WebMediaPlayerClient* client) {
|
||||||
scoped_ptr<media::MediaFilterCollection> collection(
|
scoped_ptr<media::FilterCollection> collection(
|
||||||
new media::MediaFilterCollection());
|
new media::FilterCollection());
|
||||||
|
|
||||||
appcache::WebApplicationCacheHostImpl* appcache_host =
|
// TODO(annacc): do we still need appcache_host? http://crbug.com/65135
|
||||||
appcache::WebApplicationCacheHostImpl::FromFrame(frame);
|
// appcache::WebApplicationCacheHostImpl* appcache_host =
|
||||||
|
// appcache::WebApplicationCacheHostImpl::FromFrame(frame);
|
||||||
// TODO(hclam): this is the same piece of code as in RenderView, maybe they
|
|
||||||
// should be grouped together.
|
|
||||||
webkit_glue::MediaResourceLoaderBridgeFactory* bridge_factory_simple =
|
|
||||||
new webkit_glue::MediaResourceLoaderBridgeFactory(
|
|
||||||
GURL(frame->url()), // referrer
|
|
||||||
"null", // frame origin
|
|
||||||
"null", // main_frame_origin
|
|
||||||
base::GetCurrentProcId(),
|
|
||||||
appcache_host ? appcache_host->host_id() : appcache::kNoHostId,
|
|
||||||
0);
|
|
||||||
webkit_glue::MediaResourceLoaderBridgeFactory* bridge_factory_buffered =
|
|
||||||
new webkit_glue::MediaResourceLoaderBridgeFactory(
|
|
||||||
GURL(frame->url()), // referrer
|
|
||||||
"null", // frame origin
|
|
||||||
"null", // main_frame_origin
|
|
||||||
base::GetCurrentProcId(),
|
|
||||||
appcache_host ? appcache_host->host_id() : appcache::kNoHostId,
|
|
||||||
0);
|
|
||||||
|
|
||||||
scoped_refptr<webkit_glue::VideoRendererImpl> video_renderer(
|
scoped_refptr<webkit_glue::VideoRendererImpl> video_renderer(
|
||||||
new webkit_glue::VideoRendererImpl(false));
|
new webkit_glue::VideoRendererImpl(false));
|
||||||
@@ -585,9 +569,11 @@ WebMediaPlayer* BrowserWebViewDelegate::createMediaPlayer(
|
|||||||
// Add the audio renderer.
|
// Add the audio renderer.
|
||||||
collection->AddAudioRenderer(new media::AudioRendererImpl());
|
collection->AddAudioRenderer(new media::AudioRendererImpl());
|
||||||
|
|
||||||
return new webkit_glue::WebMediaPlayerImpl(
|
scoped_ptr<webkit_glue::WebMediaPlayerImpl> result(
|
||||||
client, collection.release(), bridge_factory_simple,
|
new webkit_glue::WebMediaPlayerImpl(client, collection.release()));
|
||||||
bridge_factory_buffered, false, video_renderer);
|
if (!result->Initialize(frame, false, video_renderer))
|
||||||
|
return NULL;
|
||||||
|
return result.release();
|
||||||
}
|
}
|
||||||
|
|
||||||
WebApplicationCacheHost* BrowserWebViewDelegate::createApplicationCacheHost(
|
WebApplicationCacheHost* BrowserWebViewDelegate::createApplicationCacheHost(
|
||||||
@@ -826,15 +812,9 @@ void BrowserWebViewDelegate::reportFindInPageSelection(
|
|||||||
void BrowserWebViewDelegate::openFileSystem(
|
void BrowserWebViewDelegate::openFileSystem(
|
||||||
WebFrame* frame, WebFileSystem::Type type, long long size, bool create,
|
WebFrame* frame, WebFileSystem::Type type, long long size, bool create,
|
||||||
WebFileSystemCallbacks* callbacks) {
|
WebFileSystemCallbacks* callbacks) {
|
||||||
if (browser_->file_system_root().empty()) {
|
BrowserFileSystem* fileSystem = static_cast<BrowserFileSystem*>(
|
||||||
// The FileSystem temp directory was not initialized successfully.
|
WebKit::webKitClient()->fileSystem());
|
||||||
callbacks->didFail(WebKit::WebFileErrorSecurity);
|
fileSystem->OpenFileSystem(frame, type, size, create, callbacks);
|
||||||
} else {
|
|
||||||
// TODO(michaeln): need to put origin/type in the path.
|
|
||||||
callbacks->didOpenFileSystem(
|
|
||||||
"CefFileSystem",
|
|
||||||
webkit_glue::FilePathToWebString(browser_->file_system_root()));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Public methods ------------------------------------------------------------
|
// Public methods ------------------------------------------------------------
|
||||||
|
@@ -36,7 +36,7 @@ static int kStatsFileCounters = 200;
|
|||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
URLRequestJob* BlobURLRequestJobFactory(URLRequest* request,
|
net::URLRequestJob* BlobURLRequestJobFactory(net::URLRequest* request,
|
||||||
const std::string& scheme) {
|
const std::string& scheme) {
|
||||||
webkit_blob::BlobStorageController* blob_storage_controller =
|
webkit_blob::BlobStorageController* blob_storage_controller =
|
||||||
static_cast<BrowserRequestContext*>(request->context())->
|
static_cast<BrowserRequestContext*>(request->context())->
|
||||||
@@ -116,7 +116,7 @@ void CefProcessUIThread::Init() {
|
|||||||
|
|
||||||
gfx::InitializeGLBindings(gfx::kGLImplementationDesktopGL);
|
gfx::InitializeGLBindings(gfx::kGLImplementationDesktopGL);
|
||||||
|
|
||||||
URLRequest::RegisterProtocolFactory("blob", &BlobURLRequestJobFactory);
|
net::URLRequest::RegisterProtocolFactory("blob", &BlobURLRequestJobFactory);
|
||||||
|
|
||||||
if (!_Context->cache_path().empty()) {
|
if (!_Context->cache_path().empty()) {
|
||||||
// Create the storage context object.
|
// Create the storage context object.
|
||||||
|
@@ -96,7 +96,7 @@ void CefRequestImpl::Set(const CefString& url,
|
|||||||
Unlock();
|
Unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
void CefRequestImpl::Set(URLRequest* request)
|
void CefRequestImpl::Set(net::URLRequest* request)
|
||||||
{
|
{
|
||||||
SetURL(request->url().spec());
|
SetURL(request->url().spec());
|
||||||
SetMethod(request->method());
|
SetMethod(request->method());
|
||||||
|
@@ -11,7 +11,9 @@
|
|||||||
#include "third_party/WebKit/WebKit/chromium/public/WebHTTPBody.h"
|
#include "third_party/WebKit/WebKit/chromium/public/WebHTTPBody.h"
|
||||||
#include "third_party/WebKit/WebKit/chromium/public/WebURLRequest.h"
|
#include "third_party/WebKit/WebKit/chromium/public/WebURLRequest.h"
|
||||||
|
|
||||||
|
namespace net {
|
||||||
class URLRequest;
|
class URLRequest;
|
||||||
|
};
|
||||||
|
|
||||||
// Implementation of CefRequest
|
// Implementation of CefRequest
|
||||||
class CefRequestImpl : public CefThreadSafeBase<CefRequest>
|
class CefRequestImpl : public CefThreadSafeBase<CefRequest>
|
||||||
@@ -33,7 +35,7 @@ public:
|
|||||||
CefRefPtr<CefPostData> postData,
|
CefRefPtr<CefPostData> postData,
|
||||||
const HeaderMap& headerMap);
|
const HeaderMap& headerMap);
|
||||||
|
|
||||||
void Set(URLRequest* request);
|
void Set(net::URLRequest* request);
|
||||||
|
|
||||||
static void GetHeaderMap(const net::HttpRequestHeaders& headers,
|
static void GetHeaderMap(const net::HttpRequestHeaders& headers,
|
||||||
HeaderMap& map);
|
HeaderMap& map);
|
||||||
|
@@ -43,12 +43,12 @@ static void TrackAdd(CefTrackObject* object)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
// URLRequestJob implementation.
|
// net::URLRequestJob implementation.
|
||||||
|
|
||||||
class CefUrlRequestJob : public URLRequestJob {
|
class CefUrlRequestJob : public net::URLRequestJob {
|
||||||
public:
|
public:
|
||||||
CefUrlRequestJob(URLRequest* request, CefRefPtr<CefSchemeHandler> handler)
|
CefUrlRequestJob(net::URLRequest* request, CefRefPtr<CefSchemeHandler> handler)
|
||||||
: URLRequestJob(request),
|
: net::URLRequestJob(request),
|
||||||
handler_(handler),
|
handler_(handler),
|
||||||
response_length_(0),
|
response_length_(0),
|
||||||
url_(request->url()),
|
url_(request->url()),
|
||||||
@@ -74,7 +74,7 @@ public:
|
|||||||
async_resolver_ = NULL;
|
async_resolver_ = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
URLRequestJob::Kill();
|
net::URLRequestJob::Kill();
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual bool ReadRawData(net::IOBuffer* dest, int dest_size, int *bytes_read)
|
virtual bool ReadRawData(net::IOBuffer* dest, int dest_size, int *bytes_read)
|
||||||
@@ -229,7 +229,7 @@ private:
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
// URLRequestFilter clone that manages the CefSchemeHandlerFactory pointers.
|
// net::URLRequestFilter clone that manages the CefSchemeHandlerFactory pointers.
|
||||||
|
|
||||||
class CefUrlRequestFilter {
|
class CefUrlRequestFilter {
|
||||||
public:
|
public:
|
||||||
@@ -245,7 +245,7 @@ public:
|
|||||||
return shared_instance_;
|
return shared_instance_;
|
||||||
}
|
}
|
||||||
|
|
||||||
static URLRequestJob* Factory(URLRequest* request,
|
static net::URLRequestJob* Factory(net::URLRequest* request,
|
||||||
const std::string& scheme)
|
const std::string& scheme)
|
||||||
{
|
{
|
||||||
// Returning null here just means that the built-in handler will be used.
|
// Returning null here just means that the built-in handler will be used.
|
||||||
@@ -259,7 +259,7 @@ public:
|
|||||||
handler_map_[make_pair(scheme, hostname)] = factory;
|
handler_map_[make_pair(scheme, hostname)] = factory;
|
||||||
|
|
||||||
// Register with the ProtocolFactory.
|
// Register with the ProtocolFactory.
|
||||||
URLRequest::RegisterProtocolFactory(scheme,
|
net::URLRequest::RegisterProtocolFactory(scheme,
|
||||||
&CefUrlRequestFilter::Factory);
|
&CefUrlRequestFilter::Factory);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -285,14 +285,14 @@ public:
|
|||||||
}
|
}
|
||||||
for (std::set<std::string>::const_iterator scheme = schemes.begin();
|
for (std::set<std::string>::const_iterator scheme = schemes.begin();
|
||||||
scheme != schemes.end(); ++scheme) {
|
scheme != schemes.end(); ++scheme) {
|
||||||
URLRequest::RegisterProtocolFactory(*scheme, NULL);
|
net::URLRequest::RegisterProtocolFactory(*scheme, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
handler_map_.clear();
|
handler_map_.clear();
|
||||||
hit_count_ = 0;
|
hit_count_ = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
CefSchemeHandlerFactory* FindRequestHandlerFactory(URLRequest* request,
|
CefSchemeHandlerFactory* FindRequestHandlerFactory(net::URLRequest* request,
|
||||||
const std::string& scheme)
|
const std::string& scheme)
|
||||||
{
|
{
|
||||||
CefSchemeHandlerFactory* factory = NULL;
|
CefSchemeHandlerFactory* factory = NULL;
|
||||||
@@ -323,10 +323,10 @@ protected:
|
|||||||
CefUrlRequestFilter() : hit_count_(0) { }
|
CefUrlRequestFilter() : hit_count_(0) { }
|
||||||
|
|
||||||
// Helper method that looks up the request in the handler_map_.
|
// Helper method that looks up the request in the handler_map_.
|
||||||
URLRequestJob* FindRequestHandler(URLRequest* request,
|
net::URLRequestJob* FindRequestHandler(net::URLRequest* request,
|
||||||
const std::string& scheme)
|
const std::string& scheme)
|
||||||
{
|
{
|
||||||
URLRequestJob* job = NULL;
|
net::URLRequestJob* job = NULL;
|
||||||
CefSchemeHandlerFactory* factory =
|
CefSchemeHandlerFactory* factory =
|
||||||
FindRequestHandlerFactory(request, scheme);
|
FindRequestHandlerFactory(request, scheme);
|
||||||
if (factory) {
|
if (factory) {
|
||||||
@@ -336,7 +336,7 @@ protected:
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (job) {
|
if (job) {
|
||||||
DLOG(INFO) << "URLRequestFilter hit for " << request->url().spec();
|
DLOG(INFO) << "net::URLRequestFilter hit for " << request->url().spec();
|
||||||
hit_count_++;
|
hit_count_++;
|
||||||
}
|
}
|
||||||
return job;
|
return job;
|
||||||
|
@@ -339,3 +339,27 @@ void RunLocalStorageTest(CefRefPtr<CefBrowser> browser)
|
|||||||
{
|
{
|
||||||
browser->GetMainFrame()->LoadURL("http://tests/localstorage");
|
browser->GetMainFrame()->LoadURL("http://tests/localstorage");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void RunAccelerated2DCanvasTest(CefRefPtr<CefBrowser> browser)
|
||||||
|
{
|
||||||
|
browser->GetMainFrame()->LoadURL(
|
||||||
|
"http://mudcu.be/labs/JS1k/BreathingGalaxies.html");
|
||||||
|
}
|
||||||
|
|
||||||
|
void RunAcceleratedLayersTest(CefRefPtr<CefBrowser> browser)
|
||||||
|
{
|
||||||
|
browser->GetMainFrame()->LoadURL(
|
||||||
|
"http://webkit.org/blog-files/3d-transforms/poster-circle.html");
|
||||||
|
}
|
||||||
|
|
||||||
|
void RunWebGLTest(CefRefPtr<CefBrowser> browser)
|
||||||
|
{
|
||||||
|
browser->GetMainFrame()->LoadURL(
|
||||||
|
"http://webglsamples.googlecode.com/hg/field/field.html");
|
||||||
|
}
|
||||||
|
|
||||||
|
void RunHTML5VideoTest(CefRefPtr<CefBrowser> browser)
|
||||||
|
{
|
||||||
|
browser->GetMainFrame()->LoadURL(
|
||||||
|
"http://www.youtube.com/watch?v=siOHh0uzcuY&html5=True");
|
||||||
|
}
|
||||||
|
@@ -363,5 +363,9 @@ void RunRequestTest(CefRefPtr<CefBrowser> browser);
|
|||||||
void RunJavaScriptExecuteTest(CefRefPtr<CefBrowser> browser);
|
void RunJavaScriptExecuteTest(CefRefPtr<CefBrowser> browser);
|
||||||
void RunPopupTest(CefRefPtr<CefBrowser> browser);
|
void RunPopupTest(CefRefPtr<CefBrowser> browser);
|
||||||
void RunLocalStorageTest(CefRefPtr<CefBrowser> browser);
|
void RunLocalStorageTest(CefRefPtr<CefBrowser> browser);
|
||||||
|
void RunAccelerated2DCanvasTest(CefRefPtr<CefBrowser> browser);
|
||||||
|
void RunAcceleratedLayersTest(CefRefPtr<CefBrowser> browser);
|
||||||
|
void RunWebGLTest(CefRefPtr<CefBrowser> browser);
|
||||||
|
void RunHTML5VideoTest(CefRefPtr<CefBrowser> browser);
|
||||||
|
|
||||||
#endif // _CEFCLIENT_H
|
#endif // _CEFCLIENT_H
|
||||||
|
@@ -75,6 +75,10 @@ BEGIN
|
|||||||
MENUITEM "Scheme Handler", ID_TESTS_SCHEME_HANDLER
|
MENUITEM "Scheme Handler", ID_TESTS_SCHEME_HANDLER
|
||||||
MENUITEM "UI App Example", ID_TESTS_UIAPP
|
MENUITEM "UI App Example", ID_TESTS_UIAPP
|
||||||
MENUITEM "Local Storage", ID_TESTS_LOCALSTORAGE
|
MENUITEM "Local Storage", ID_TESTS_LOCALSTORAGE
|
||||||
|
MENUITEM "Accelerated 2D Canvas", ID_TESTS_ACCELERATED2DCANVAS
|
||||||
|
MENUITEM "Accelerated Layers", ID_TESTS_ACCELERATEDLAYERS
|
||||||
|
MENUITEM "WebGL", ID_TESTS_WEBGL
|
||||||
|
MENUITEM "HTML5 Video", ID_TESTS_HTML5VIDEO
|
||||||
END
|
END
|
||||||
END
|
END
|
||||||
|
|
||||||
|
@@ -548,6 +548,22 @@ LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
|
|||||||
if(browser.get())
|
if(browser.get())
|
||||||
RunLocalStorageTest(browser);
|
RunLocalStorageTest(browser);
|
||||||
return 0;
|
return 0;
|
||||||
|
case ID_TESTS_ACCELERATED2DCANVAS: // Test accelerated 2d canvas
|
||||||
|
if(browser.get())
|
||||||
|
RunAccelerated2DCanvasTest(browser);
|
||||||
|
return 0;
|
||||||
|
case ID_TESTS_ACCELERATEDLAYERS: // Test accelerated layers
|
||||||
|
if(browser.get())
|
||||||
|
RunAcceleratedLayersTest(browser);
|
||||||
|
return 0;
|
||||||
|
case ID_TESTS_WEBGL: // Test WebGL
|
||||||
|
if(browser.get())
|
||||||
|
RunWebGLTest(browser);
|
||||||
|
return 0;
|
||||||
|
case ID_TESTS_HTML5VIDEO: // Test HTML5 video
|
||||||
|
if(browser.get())
|
||||||
|
RunHTML5VideoTest(browser);
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@@ -37,6 +37,10 @@
|
|||||||
#define ID_TESTS_SCHEME_HANDLER 32777
|
#define ID_TESTS_SCHEME_HANDLER 32777
|
||||||
#define ID_TESTS_UIAPP 32778
|
#define ID_TESTS_UIAPP 32778
|
||||||
#define ID_TESTS_LOCALSTORAGE 32779
|
#define ID_TESTS_LOCALSTORAGE 32779
|
||||||
|
#define ID_TESTS_ACCELERATED2DCANVAS 32780
|
||||||
|
#define ID_TESTS_ACCELERATEDLAYERS 32781
|
||||||
|
#define ID_TESTS_WEBGL 32782
|
||||||
|
#define ID_TESTS_HTML5VIDEO 32783
|
||||||
#define IDC_STATIC -1
|
#define IDC_STATIC -1
|
||||||
#define IDS_LOGO 1000
|
#define IDS_LOGO 1000
|
||||||
#define IDS_UIPLUGIN 1001
|
#define IDS_UIPLUGIN 1001
|
||||||
|
@@ -1,2 +1,2 @@
|
|||||||
@echo off
|
@echo off
|
||||||
..\third_party\python_24\python.exe tools\patcher.py --patch-config patch/patch_build.cfg
|
..\third_party\python_26\python.exe tools\patcher.py --patch-config patch/patch_build.cfg
|
@@ -1,2 +1,2 @@
|
|||||||
@echo off
|
@echo off
|
||||||
..\third_party\python_24\python.exe tools\patcher.py --patch-config patch/patch_source.cfg
|
..\third_party\python_26\python.exe tools\patcher.py --patch-config patch/patch_source.cfg
|
@@ -1,3 +1,3 @@
|
|||||||
@echo off
|
@echo off
|
||||||
..\..\third_party\python_24\python.exe translator.py --cpp-header ..\include\cef.h --capi-header ..\include\cef_capi.h --cpptoc-dir ..\libcef_dll\cpptoc --ctocpp-dir ..\libcef_dll\ctocpp
|
..\..\third_party\python_26\python.exe translator.py --cpp-header ..\include\cef.h --capi-header ..\include\cef_capi.h --cpptoc-dir ..\libcef_dll\cpptoc --ctocpp-dir ..\libcef_dll\ctocpp
|
||||||
pause
|
pause
|
Reference in New Issue
Block a user