mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2025-06-05 21:39:12 +02:00
Improve inheritance support in the CEF API (issue #1623).
- Support single parent inheritance in CEF API classes. - Support non-virtual inheritance in CEF API classes. - Support translation of CEF API sub-directories. - Add test sub-directories for testing-only functionality that will be available to unit tests but not exposed via the binary distribution. - Add unit tests for the translator tool. - Fix parsing of template parameter types that include commas.
This commit is contained in:
@ -14,6 +14,8 @@
|
||||
#include "libcef_dll/ctocpp/v8value_ctocpp.h"
|
||||
|
||||
|
||||
namespace {
|
||||
|
||||
// MEMBER FUNCTIONS - Body may be edited by hand.
|
||||
|
||||
int CEF_CALLBACK v8accessor_get(struct _cef_v8accessor_t* self,
|
||||
@ -110,13 +112,21 @@ int CEF_CALLBACK v8accessor_set(struct _cef_v8accessor_t* self,
|
||||
return _retval;
|
||||
}
|
||||
|
||||
} // namespace
|
||||
|
||||
|
||||
// CONSTRUCTOR - Do not edit by hand.
|
||||
|
||||
CefV8AccessorCppToC::CefV8AccessorCppToC(CefV8Accessor* cls)
|
||||
: CefCppToC<CefV8AccessorCppToC, CefV8Accessor, cef_v8accessor_t>(cls) {
|
||||
struct_.struct_.get = v8accessor_get;
|
||||
struct_.struct_.set = v8accessor_set;
|
||||
CefV8AccessorCppToC::CefV8AccessorCppToC() {
|
||||
GetStruct()->get = v8accessor_get;
|
||||
GetStruct()->set = v8accessor_set;
|
||||
}
|
||||
|
||||
template<> CefRefPtr<CefV8Accessor> CefCppToC<CefV8AccessorCppToC,
|
||||
CefV8Accessor, cef_v8accessor_t>::UnwrapDerived(CefWrapperType type,
|
||||
cef_v8accessor_t* s) {
|
||||
NOTREACHED() << "Unexpected class type: " << type;
|
||||
return NULL;
|
||||
}
|
||||
|
||||
#ifndef NDEBUG
|
||||
@ -124,3 +134,5 @@ template<> base::AtomicRefCount CefCppToC<CefV8AccessorCppToC, CefV8Accessor,
|
||||
cef_v8accessor_t>::DebugObjCt = 0;
|
||||
#endif
|
||||
|
||||
template<> CefWrapperType CefCppToC<CefV8AccessorCppToC, CefV8Accessor,
|
||||
cef_v8accessor_t>::kWrapperType = WT_V8ACCESSOR;
|
||||
|
Reference in New Issue
Block a user