mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2025-06-05 21:39:12 +02:00
- Fix memory leaks in V8 usage (issue #323).
- Improve performance of V8 string conversions (issue #323). - Add V8 performance test to cefclient (issue #323). - Add the ability to return exceptions from V8 accessors (issue #327). - Return undefined instead of null from a V8 handler if no return value is specified (issue #329). git-svn-id: https://chromiumembedded.googlecode.com/svn/trunk@291 5089003a-bbd8-11dd-ad1f-f1f9622dbc98
This commit is contained in:
@@ -17,7 +17,8 @@
|
||||
// VIRTUAL METHODS - Body may be edited by hand.
|
||||
|
||||
bool CefV8AccessorCToCpp::Get(const CefString& name,
|
||||
const CefRefPtr<CefV8Value> object, CefRefPtr<CefV8Value>& retval)
|
||||
const CefRefPtr<CefV8Value> object, CefRefPtr<CefV8Value>& retval,
|
||||
CefString& exception)
|
||||
{
|
||||
if(CEF_MEMBER_MISSING(struct_, get))
|
||||
return false;
|
||||
@@ -25,7 +26,8 @@ bool CefV8AccessorCToCpp::Get(const CefString& name,
|
||||
cef_v8value_t* retvalStruct = NULL;
|
||||
|
||||
int rv = struct_->get(struct_, name.GetStruct(),
|
||||
CefV8ValueCppToC::Wrap(object), &retvalStruct);
|
||||
CefV8ValueCppToC::Wrap(object), &retvalStruct,
|
||||
exception.GetWritableStruct());
|
||||
if(retvalStruct)
|
||||
retval = CefV8ValueCppToC::Unwrap(retvalStruct);
|
||||
|
||||
@@ -33,14 +35,16 @@ bool CefV8AccessorCToCpp::Get(const CefString& name,
|
||||
}
|
||||
|
||||
bool CefV8AccessorCToCpp::Set(const CefString& name,
|
||||
const CefRefPtr<CefV8Value> object, const CefRefPtr<CefV8Value> value)
|
||||
const CefRefPtr<CefV8Value> object, const CefRefPtr<CefV8Value> value,
|
||||
CefString& exception)
|
||||
{
|
||||
if(CEF_MEMBER_MISSING(struct_, set))
|
||||
return false;
|
||||
|
||||
int rv = struct_->set(struct_, name.GetStruct(),
|
||||
CefV8ValueCppToC::Wrap(object),
|
||||
CefV8ValueCppToC::Wrap(value));
|
||||
CefV8ValueCppToC::Wrap(value),
|
||||
exception.GetWritableStruct());
|
||||
|
||||
return rv ? true : false;
|
||||
}
|
||||
|
Reference in New Issue
Block a user