mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2024-12-13 18:16:20 +01:00
dbe8de277f
- Replace CefHandler with a new CefClient interface and separate handler interfaces. - Add support for virtual inheritance to allow multiple CefBase parented interfaces to be implemented in the same class. - Replace CefThreadSafeBase with IMPLEMENT_* macros to support virtual inheritance and to only provide locking implementations when needed. - Move the CefBrowserSettings parameter from CefInitialize to CreateBrowser. - Add a new cef_build.h header that provides platform-specific and OS_* defines. - Introduce the use of OVERRIDE to generate compiler errors on Windows if a child virtual method declaration doesn't match the parent declaration. - Use NDEBUG instead of _DEBUG because _DEBUG is not defined on Mac. (issue #240). git-svn-id: https://chromiumembedded.googlecode.com/svn/trunk@235 5089003a-bbd8-11dd-ad1f-f1f9622dbc98
63 lines
1.8 KiB
C++
63 lines
1.8 KiB
C++
// Copyright (c) 2011 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.
|
|
//
|
|
// ---------------------------------------------------------------------------
|
|
//
|
|
// A portion of this file was generated by the CEF translator tool. When
|
|
// making changes by hand only do so within the body of existing function
|
|
// implementations. See the translator.README.txt file in the tools directory
|
|
// for more information.
|
|
//
|
|
|
|
#include "libcef_dll/cpptoc/v8handler_cpptoc.h"
|
|
#include "libcef_dll/ctocpp/v8value_ctocpp.h"
|
|
|
|
|
|
// MEMBER FUNCTIONS - Body may be edited by hand.
|
|
|
|
int CEF_CALLBACK v8handler_execute(struct _cef_v8handler_t* self,
|
|
const cef_string_t* name, struct _cef_v8value_t* object,
|
|
size_t argumentCount, struct _cef_v8value_t* const* arguments,
|
|
struct _cef_v8value_t** retval, cef_string_t* exception)
|
|
{
|
|
DCHECK(self);
|
|
if(!self)
|
|
return 0;
|
|
|
|
CefRefPtr<CefV8Value> objectPtr;
|
|
if(object)
|
|
objectPtr = CefV8ValueCToCpp::Wrap(object);
|
|
|
|
CefV8ValueList list;
|
|
for(size_t i = 0; i < argumentCount; ++i) {
|
|
list.push_back(CefV8ValueCToCpp::Wrap(arguments[i]));
|
|
}
|
|
|
|
CefRefPtr<CefV8Value> retValPtr;
|
|
CefString exceptionStr(exception);
|
|
bool rv = CefV8HandlerCppToC::Get(self)->Execute(CefString(name), objectPtr,
|
|
list, retValPtr, exceptionStr);
|
|
if(rv) {
|
|
if(retValPtr.get() && retval)
|
|
*retval = CefV8ValueCToCpp::Unwrap(retValPtr);
|
|
}
|
|
|
|
return rv;
|
|
}
|
|
|
|
|
|
// CONSTRUCTOR - Do not edit by hand.
|
|
|
|
CefV8HandlerCppToC::CefV8HandlerCppToC(CefV8Handler* cls)
|
|
: CefCppToC<CefV8HandlerCppToC, CefV8Handler, cef_v8handler_t>(cls)
|
|
{
|
|
struct_.struct_.execute = v8handler_execute;
|
|
}
|
|
|
|
#ifndef NDEBUG
|
|
template<> long CefCppToC<CefV8HandlerCppToC, CefV8Handler,
|
|
cef_v8handler_t>::DebugObjCt = 0;
|
|
#endif
|
|
|