mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2024-12-27 10:03:31 +01:00
afe3cb1d67
- Add CefRenderProcessHandler callbacks for WebWorker context creation, release and uncaught exceptions. - Add CefTaskRunner class that supports posting of tasks to standard threads and WebWorker threads. - Organize V8 internal state information on a per-thread/per-Isolate basis. - Add webkit_451.patch that provides the WebKit implementation. git-svn-id: https://chromiumembedded.googlecode.com/svn/trunk@972 5089003a-bbd8-11dd-ad1f-f1f9622dbc98
59 lines
1.7 KiB
C++
59 lines
1.7 KiB
C++
// Copyright (c) 2013 The Chromium Embedded Framework Authors. All rights
|
|
// reserved. Use of this source code is governed by a BSD-style license that
|
|
// can be found in the LICENSE file.
|
|
|
|
#ifndef CEF_LIBCEF_RENDERER_THREAD_UTIL_H_
|
|
#define CEF_LIBCEF_RENDERER_THREAD_UTIL_H_
|
|
#pragma once
|
|
|
|
#include "libcef/renderer/content_renderer_client.h"
|
|
|
|
#include "base/location.h"
|
|
#include "base/logging.h"
|
|
#include "content/public/renderer/render_thread.h"
|
|
|
|
#define CEF_CURRENTLY_ON_RT() (!!content::RenderThread::Get())
|
|
|
|
#define CEF_REQUIRE_RT() DCHECK(CEF_CURRENTLY_ON_RT())
|
|
|
|
#define CEF_REQUIRE_RT_RETURN(var) \
|
|
if (!CEF_CURRENTLY_ON_RT()) { \
|
|
NOTREACHED() << "called on invalid thread"; \
|
|
return var; \
|
|
}
|
|
|
|
#define CEF_REQUIRE_RT_RETURN_VOID() \
|
|
if (!CEF_CURRENTLY_ON_RT()) { \
|
|
NOTREACHED() << "called on invalid thread"; \
|
|
return; \
|
|
}
|
|
|
|
#define CEF_RENDER_LOOP() \
|
|
(CefContentRendererClient::Get()->render_task_runner())
|
|
|
|
#define CEF_POST_TASK_RT(task) \
|
|
CEF_RENDER_LOOP()->PostTask(FROM_HERE, task)
|
|
#define CEF_POST_DELAYED_TASK_RT(task, delay_ms) \
|
|
CEF_RENDER_LOOP()->PostDelayedTask(FROM_HERE, task, delay_ms)
|
|
|
|
// Use this template in conjuction with RefCountedThreadSafe when you want to
|
|
// ensure that an object is deleted on the render thread.
|
|
struct CefDeleteOnRenderThread {
|
|
template<typename T>
|
|
static void Destruct(const T* x) {
|
|
if (CEF_CURRENTLY_ON_RT()) {
|
|
delete x;
|
|
} else {
|
|
if (!CEF_RENDER_LOOP()->DeleteSoon(FROM_HERE, x)) {
|
|
#if defined(UNIT_TEST)
|
|
// Only logged under unit testing because leaks at shutdown
|
|
// are acceptable under normal circumstances.
|
|
LOG(ERROR) << "DeleteSoon failed on thread " << thread;
|
|
#endif // UNIT_TEST
|
|
}
|
|
}
|
|
}
|
|
};
|
|
|
|
#endif // CEF_LIBCEF_RENDERER_THREAD_UTIL_H_
|