mirror of
https://github.com/phpv8/v8js.git
synced 2025-01-03 14:31:53 +00:00
Merge pull request #234 from stesie/fix-build-v8-5.2
Fix build against V8 5.2
This commit is contained in:
commit
450a7a1092
@ -20,7 +20,8 @@ Minimum requirements
|
|||||||
V8 is Google's open source Javascript engine.
|
V8 is Google's open source Javascript engine.
|
||||||
V8 is written in C++ and is used in Google Chrome, the open source browser from Google.
|
V8 is written in C++ and is used in Google Chrome, the open source browser from Google.
|
||||||
V8 implements ECMAScript as specified in ECMA-262, 5th edition.
|
V8 implements ECMAScript as specified in ECMA-262, 5th edition.
|
||||||
This extension makes use of V8 isolates to ensure separation between multiple V8Js instances and uses the new isolate-based mechanism to throw exceptions, hence the need for 3.24.6 or above.
|
|
||||||
|
This extension requires V8 4.6.76 or higher.
|
||||||
|
|
||||||
V8 releases are published rather quickly and the V8 team usually provides security support
|
V8 releases are published rather quickly and the V8 team usually provides security support
|
||||||
for the version line shipped with the Chrome browser (stable channel) and newer (only).
|
for the version line shipped with the Chrome browser (stable channel) and newer (only).
|
||||||
|
32
config.m4
32
config.m4
@ -121,8 +121,8 @@ int main ()
|
|||||||
set $ac_cv_v8_version
|
set $ac_cv_v8_version
|
||||||
IFS=$ac_IFS
|
IFS=$ac_IFS
|
||||||
V8_API_VERSION=`expr [$]1 \* 1000000 + [$]2 \* 1000 + [$]3`
|
V8_API_VERSION=`expr [$]1 \* 1000000 + [$]2 \* 1000 + [$]3`
|
||||||
if test "$V8_API_VERSION" -lt 3024006 ; then
|
if test "$V8_API_VERSION" -lt 4006076 ; then
|
||||||
AC_MSG_ERROR([libv8 must be version 3.24.6 or greater])
|
AC_MSG_ERROR([libv8 must be version 4.6.76 or greater])
|
||||||
fi
|
fi
|
||||||
AC_DEFINE_UNQUOTED([PHP_V8_API_VERSION], $V8_API_VERSION, [ ])
|
AC_DEFINE_UNQUOTED([PHP_V8_API_VERSION], $V8_API_VERSION, [ ])
|
||||||
AC_DEFINE_UNQUOTED([PHP_V8_VERSION], "$ac_cv_v8_version", [ ])
|
AC_DEFINE_UNQUOTED([PHP_V8_VERSION], "$ac_cv_v8_version", [ ])
|
||||||
@ -130,10 +130,6 @@ int main ()
|
|||||||
AC_MSG_ERROR([could not determine libv8 version])
|
AC_MSG_ERROR([could not determine libv8 version])
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if test "$V8_API_VERSION" -ge 3029036 ; then
|
|
||||||
dnl building for v8 3.29.36 or later, which requires us to
|
|
||||||
dnl initialize and provide a platform; hence we need to
|
|
||||||
dnl link in libplatform to make our life easier.
|
|
||||||
PHP_ADD_INCLUDE($V8_DIR)
|
PHP_ADD_INCLUDE($V8_DIR)
|
||||||
|
|
||||||
case $host_os in
|
case $host_os in
|
||||||
@ -149,16 +145,15 @@ int main ()
|
|||||||
for static_link_extra_file in $static_link_extra; do
|
for static_link_extra_file in $static_link_extra; do
|
||||||
AC_MSG_CHECKING([for $static_link_extra_file])
|
AC_MSG_CHECKING([for $static_link_extra_file])
|
||||||
|
|
||||||
for i in $PHP_V8JS $SEARCH_PATH ; do
|
if test -r $V8_DIR/lib64/$static_link_extra_file; then
|
||||||
if test -r $i/lib64/$static_link_extra_file; then
|
static_link_dir=$V8_DIR/lib64
|
||||||
static_link_dir=$i/lib64
|
AC_MSG_RESULT(found in $V8_DIR/lib64)
|
||||||
AC_MSG_RESULT(found in $i)
|
|
||||||
fi
|
fi
|
||||||
if test -r $i/lib/$static_link_extra_file; then
|
|
||||||
static_link_dir=$i/lib
|
if test -r $V8_DIR/lib/$static_link_extra_file; then
|
||||||
AC_MSG_RESULT(found in $i)
|
static_link_dir=$V8_DIR/lib
|
||||||
|
AC_MSG_RESULT(found in $V8_DIR/lib)
|
||||||
fi
|
fi
|
||||||
done
|
|
||||||
|
|
||||||
if test -z "$static_link_dir"; then
|
if test -z "$static_link_dir"; then
|
||||||
AC_MSG_RESULT([not found])
|
AC_MSG_RESULT([not found])
|
||||||
@ -171,9 +166,7 @@ int main ()
|
|||||||
# modify flags for (possibly) succeeding V8 startup check
|
# modify flags for (possibly) succeeding V8 startup check
|
||||||
CPPFLAGS="$CPPFLAGS -I$V8_DIR"
|
CPPFLAGS="$CPPFLAGS -I$V8_DIR"
|
||||||
LIBS="$LIBS $LDFLAGS_libplatform"
|
LIBS="$LIBS $LDFLAGS_libplatform"
|
||||||
fi
|
|
||||||
|
|
||||||
if test "$V8_API_VERSION" -ge 4004010 ; then
|
|
||||||
dnl building for v8 4.4.10 or later, which requires us to
|
dnl building for v8 4.4.10 or later, which requires us to
|
||||||
dnl provide startup data, if V8 wasn't compiled with snapshot=off.
|
dnl provide startup data, if V8 wasn't compiled with snapshot=off.
|
||||||
AC_MSG_CHECKING([whether V8 requires startup data])
|
AC_MSG_CHECKING([whether V8 requires startup data])
|
||||||
@ -183,7 +176,6 @@ int main ()
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#if PHP_V8_API_VERSION >= 4004010
|
|
||||||
class ArrayBufferAllocator : public v8::ArrayBuffer::Allocator {
|
class ArrayBufferAllocator : public v8::ArrayBuffer::Allocator {
|
||||||
public:
|
public:
|
||||||
virtual void* Allocate(size_t length) {
|
virtual void* Allocate(size_t length) {
|
||||||
@ -193,7 +185,6 @@ public:
|
|||||||
virtual void* AllocateUninitialized(size_t length) { return malloc(length); }
|
virtual void* AllocateUninitialized(size_t length) { return malloc(length); }
|
||||||
virtual void Free(void* data, size_t) { free(data); }
|
virtual void Free(void* data, size_t) { free(data); }
|
||||||
};
|
};
|
||||||
#endif
|
|
||||||
|
|
||||||
int main ()
|
int main ()
|
||||||
{
|
{
|
||||||
@ -201,15 +192,11 @@ public:
|
|||||||
v8::V8::InitializePlatform(v8_platform);
|
v8::V8::InitializePlatform(v8_platform);
|
||||||
v8::V8::Initialize();
|
v8::V8::Initialize();
|
||||||
|
|
||||||
#if PHP_V8_API_VERSION >= 4004044
|
|
||||||
static ArrayBufferAllocator array_buffer_allocator;
|
static ArrayBufferAllocator array_buffer_allocator;
|
||||||
v8::Isolate::CreateParams create_params;
|
v8::Isolate::CreateParams create_params;
|
||||||
create_params.array_buffer_allocator = &array_buffer_allocator;
|
create_params.array_buffer_allocator = &array_buffer_allocator;
|
||||||
|
|
||||||
v8::Isolate::New(create_params);
|
v8::Isolate::New(create_params);
|
||||||
#else /* PHP_V8_API_VERSION < 4004044 */
|
|
||||||
v8::Isolate::New();
|
|
||||||
#endif
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
], [
|
], [
|
||||||
@ -252,7 +239,6 @@ public:
|
|||||||
AC_MSG_ERROR([Please provide V8 snapshot blob as needed])
|
AC_MSG_ERROR([Please provide V8 snapshot blob as needed])
|
||||||
fi
|
fi
|
||||||
])
|
])
|
||||||
fi
|
|
||||||
|
|
||||||
AC_LANG_RESTORE
|
AC_LANG_RESTORE
|
||||||
LIBS=$old_LIBS
|
LIBS=$old_LIBS
|
||||||
|
@ -55,9 +55,6 @@ extern "C" {
|
|||||||
/* V8Js Version */
|
/* V8Js Version */
|
||||||
#define PHP_V8JS_VERSION "0.6.2"
|
#define PHP_V8JS_VERSION "0.6.2"
|
||||||
|
|
||||||
/* Hidden field name used to link JS wrappers with underlying PHP object */
|
|
||||||
#define PHPJS_OBJECT_KEY "phpjs::object"
|
|
||||||
|
|
||||||
/* Helper macros */
|
/* Helper macros */
|
||||||
#define V8JS_GET_CLASS_NAME(var, obj) \
|
#define V8JS_GET_CLASS_NAME(var, obj) \
|
||||||
v8::String::Utf8Value var(obj->GetConstructorName());
|
v8::String::Utf8Value var(obj->GetConstructorName());
|
||||||
@ -167,9 +164,7 @@ struct _v8js_process_globals {
|
|||||||
/* V8 command line flags */
|
/* V8 command line flags */
|
||||||
char *v8_flags;
|
char *v8_flags;
|
||||||
|
|
||||||
#if !defined(_WIN32) && PHP_V8_API_VERSION >= 3029036
|
|
||||||
v8::Platform *v8_platform;
|
v8::Platform *v8_platform;
|
||||||
#endif
|
|
||||||
};
|
};
|
||||||
|
|
||||||
extern struct _v8js_process_globals v8js_process_globals;
|
extern struct _v8js_process_globals v8js_process_globals;
|
||||||
|
2
v8js.cc
2
v8js.cc
@ -150,11 +150,9 @@ static PHP_MSHUTDOWN_FUNCTION(v8js)
|
|||||||
|
|
||||||
if(v8_initialized) {
|
if(v8_initialized) {
|
||||||
v8::V8::Dispose();
|
v8::V8::Dispose();
|
||||||
#if !defined(_WIN32) && PHP_V8_API_VERSION >= 3029036
|
|
||||||
v8::V8::ShutdownPlatform();
|
v8::V8::ShutdownPlatform();
|
||||||
// @fixme call virtual destructor somehow
|
// @fixme call virtual destructor somehow
|
||||||
//delete v8js_process_globals.v8_platform;
|
//delete v8js_process_globals.v8_platform;
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (v8js_process_globals.v8_flags) {
|
if (v8js_process_globals.v8_flags) {
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
+----------------------------------------------------------------------+
|
+----------------------------------------------------------------------+
|
||||||
| PHP Version 5 |
|
| PHP Version 5 |
|
||||||
+----------------------------------------------------------------------+
|
+----------------------------------------------------------------------+
|
||||||
| Copyright (c) 1997-2013 The PHP Group |
|
| Copyright (c) 1997-2016 The PHP Group |
|
||||||
+----------------------------------------------------------------------+
|
+----------------------------------------------------------------------+
|
||||||
| http://www.opensource.org/licenses/mit-license.php MIT License |
|
| http://www.opensource.org/licenses/mit-license.php MIT License |
|
||||||
+----------------------------------------------------------------------+
|
+----------------------------------------------------------------------+
|
||||||
@ -73,8 +73,7 @@ void v8js_array_access_getter(uint32_t index, const v8::PropertyCallbackInfo<v8:
|
|||||||
|
|
||||||
V8JS_TSRMLS_FETCH();
|
V8JS_TSRMLS_FETCH();
|
||||||
|
|
||||||
v8::Local<v8::Value> php_object = self->GetHiddenValue(V8JS_SYM(PHPJS_OBJECT_KEY));
|
zval *object = reinterpret_cast<zval *>(self->GetAlignedPointerFromInternalField(1));
|
||||||
zval *object = reinterpret_cast<zval *>(v8::External::Cast(*php_object)->Value());
|
|
||||||
|
|
||||||
zval *php_value = v8js_array_access_dispatch(object, "offsetGet", 1, index, NULL TSRMLS_CC);
|
zval *php_value = v8js_array_access_dispatch(object, "offsetGet", 1, index, NULL TSRMLS_CC);
|
||||||
v8::Local<v8::Value> ret_value = zval_to_v8js(php_value, isolate TSRMLS_CC);
|
v8::Local<v8::Value> ret_value = zval_to_v8js(php_value, isolate TSRMLS_CC);
|
||||||
@ -92,8 +91,7 @@ void v8js_array_access_setter(uint32_t index, v8::Local<v8::Value> value,
|
|||||||
|
|
||||||
V8JS_TSRMLS_FETCH();
|
V8JS_TSRMLS_FETCH();
|
||||||
|
|
||||||
v8::Local<v8::Value> php_object = self->GetHiddenValue(V8JS_SYM(PHPJS_OBJECT_KEY));
|
zval *object = reinterpret_cast<zval *>(self->GetAlignedPointerFromInternalField(1));
|
||||||
zval *object = reinterpret_cast<zval *>(v8::External::Cast(*php_object)->Value());
|
|
||||||
|
|
||||||
zval *zvalue_ptr;
|
zval *zvalue_ptr;
|
||||||
MAKE_STD_ZVAL(zvalue_ptr);
|
MAKE_STD_ZVAL(zvalue_ptr);
|
||||||
@ -156,8 +154,7 @@ static void v8js_array_access_length(v8::Local<v8::String> property, const v8::P
|
|||||||
|
|
||||||
V8JS_TSRMLS_FETCH();
|
V8JS_TSRMLS_FETCH();
|
||||||
|
|
||||||
v8::Local<v8::Value> php_object = self->GetHiddenValue(V8JS_SYM(PHPJS_OBJECT_KEY));
|
zval *object = reinterpret_cast<zval *>(self->GetAlignedPointerFromInternalField(1));
|
||||||
zval *object = reinterpret_cast<zval *>(v8::External::Cast(*php_object)->Value());
|
|
||||||
|
|
||||||
int length = v8js_array_access_get_count_result(object TSRMLS_CC);
|
int length = v8js_array_access_get_count_result(object TSRMLS_CC);
|
||||||
info.GetReturnValue().Set(V8JS_INT(length));
|
info.GetReturnValue().Set(V8JS_INT(length));
|
||||||
@ -171,8 +168,7 @@ void v8js_array_access_deleter(uint32_t index, const v8::PropertyCallbackInfo<v8
|
|||||||
|
|
||||||
V8JS_TSRMLS_FETCH();
|
V8JS_TSRMLS_FETCH();
|
||||||
|
|
||||||
v8::Local<v8::Value> php_object = self->GetHiddenValue(V8JS_SYM(PHPJS_OBJECT_KEY));
|
zval *object = reinterpret_cast<zval *>(self->GetAlignedPointerFromInternalField(1));
|
||||||
zval *object = reinterpret_cast<zval *>(v8::External::Cast(*php_object)->Value());
|
|
||||||
|
|
||||||
zval *php_value = v8js_array_access_dispatch(object, "offsetUnset", 1, index, NULL TSRMLS_CC);
|
zval *php_value = v8js_array_access_dispatch(object, "offsetUnset", 1, index, NULL TSRMLS_CC);
|
||||||
zval_ptr_dtor(&php_value);
|
zval_ptr_dtor(&php_value);
|
||||||
@ -188,8 +184,7 @@ void v8js_array_access_query(uint32_t index, const v8::PropertyCallbackInfo<v8::
|
|||||||
|
|
||||||
V8JS_TSRMLS_FETCH();
|
V8JS_TSRMLS_FETCH();
|
||||||
|
|
||||||
v8::Local<v8::Value> php_object = self->GetHiddenValue(V8JS_SYM(PHPJS_OBJECT_KEY));
|
zval *object = reinterpret_cast<zval *>(self->GetAlignedPointerFromInternalField(1));
|
||||||
zval *object = reinterpret_cast<zval *>(v8::External::Cast(*php_object)->Value());
|
|
||||||
|
|
||||||
/* If index is set, then return an integer encoding a v8::PropertyAttribute;
|
/* If index is set, then return an integer encoding a v8::PropertyAttribute;
|
||||||
* otherwise we're expected to return an empty handle. */
|
* otherwise we're expected to return an empty handle. */
|
||||||
@ -207,8 +202,7 @@ void v8js_array_access_enumerator(const v8::PropertyCallbackInfo<v8::Array>& inf
|
|||||||
|
|
||||||
V8JS_TSRMLS_FETCH();
|
V8JS_TSRMLS_FETCH();
|
||||||
|
|
||||||
v8::Local<v8::Value> php_object = self->GetHiddenValue(V8JS_SYM(PHPJS_OBJECT_KEY));
|
zval *object = reinterpret_cast<zval *>(self->GetAlignedPointerFromInternalField(1));
|
||||||
zval *object = reinterpret_cast<zval *>(v8::External::Cast(*php_object)->Value());
|
|
||||||
|
|
||||||
int length = v8js_array_access_get_count_result(object TSRMLS_CC);
|
int length = v8js_array_access_get_count_result(object TSRMLS_CC);
|
||||||
v8::Local<v8::Array> result = v8::Array::New(isolate, length);
|
v8::Local<v8::Array> result = v8::Array::New(isolate, length);
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
+----------------------------------------------------------------------+
|
+----------------------------------------------------------------------+
|
||||||
| PHP Version 5 |
|
| PHP Version 5 |
|
||||||
+----------------------------------------------------------------------+
|
+----------------------------------------------------------------------+
|
||||||
| Copyright (c) 1997-2015 The PHP Group |
|
| Copyright (c) 1997-2016 The PHP Group |
|
||||||
+----------------------------------------------------------------------+
|
+----------------------------------------------------------------------+
|
||||||
| http://www.opensource.org/licenses/mit-license.php MIT License |
|
| http://www.opensource.org/licenses/mit-license.php MIT License |
|
||||||
+----------------------------------------------------------------------+
|
+----------------------------------------------------------------------+
|
||||||
@ -71,7 +71,6 @@ struct v8js_jsext {
|
|||||||
};
|
};
|
||||||
/* }}} */
|
/* }}} */
|
||||||
|
|
||||||
#if PHP_V8_API_VERSION >= 4004010
|
|
||||||
class ArrayBufferAllocator : public v8::ArrayBuffer::Allocator {
|
class ArrayBufferAllocator : public v8::ArrayBuffer::Allocator {
|
||||||
public:
|
public:
|
||||||
virtual void* Allocate(size_t length) {
|
virtual void* Allocate(size_t length) {
|
||||||
@ -81,7 +80,6 @@ public:
|
|||||||
virtual void* AllocateUninitialized(size_t length) { return malloc(length); }
|
virtual void* AllocateUninitialized(size_t length) { return malloc(length); }
|
||||||
virtual void Free(void* data, size_t) { free(data); }
|
virtual void Free(void* data, size_t) { free(data); }
|
||||||
};
|
};
|
||||||
#endif
|
|
||||||
|
|
||||||
static void v8js_free_storage(void *object TSRMLS_DC) /* {{{ */
|
static void v8js_free_storage(void *object TSRMLS_DC) /* {{{ */
|
||||||
{
|
{
|
||||||
@ -207,11 +205,9 @@ static void v8js_free_storage(void *object TSRMLS_DC) /* {{{ */
|
|||||||
c->modules_stack.~vector();
|
c->modules_stack.~vector();
|
||||||
c->modules_base.~vector();
|
c->modules_base.~vector();
|
||||||
|
|
||||||
#if PHP_V8_API_VERSION >= 4003007
|
|
||||||
if (c->zval_snapshot_blob) {
|
if (c->zval_snapshot_blob) {
|
||||||
zval_ptr_dtor(&c->zval_snapshot_blob);
|
zval_ptr_dtor(&c->zval_snapshot_blob);
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
efree(object);
|
efree(object);
|
||||||
}
|
}
|
||||||
@ -367,13 +363,10 @@ static PHP_METHOD(V8Js, __construct)
|
|||||||
c->pending_exception = NULL;
|
c->pending_exception = NULL;
|
||||||
c->in_execution = 0;
|
c->in_execution = 0;
|
||||||
|
|
||||||
#if PHP_V8_API_VERSION >= 4003007
|
|
||||||
new (&c->create_params) v8::Isolate::CreateParams();
|
new (&c->create_params) v8::Isolate::CreateParams();
|
||||||
|
|
||||||
#if PHP_V8_API_VERSION >= 4004044
|
|
||||||
static ArrayBufferAllocator array_buffer_allocator;
|
static ArrayBufferAllocator array_buffer_allocator;
|
||||||
c->create_params.array_buffer_allocator = &array_buffer_allocator;
|
c->create_params.array_buffer_allocator = &array_buffer_allocator;
|
||||||
#endif
|
|
||||||
|
|
||||||
new (&c->snapshot_blob) v8::StartupData();
|
new (&c->snapshot_blob) v8::StartupData();
|
||||||
if (snapshot_blob) {
|
if (snapshot_blob) {
|
||||||
@ -390,10 +383,6 @@ static PHP_METHOD(V8Js, __construct)
|
|||||||
}
|
}
|
||||||
|
|
||||||
c->isolate = v8::Isolate::New(c->create_params);
|
c->isolate = v8::Isolate::New(c->create_params);
|
||||||
#else /* PHP_V8_API_VERSION < 4003007 */
|
|
||||||
c->isolate = v8::Isolate::New();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
c->isolate->SetData(0, c);
|
c->isolate->SetData(0, c);
|
||||||
|
|
||||||
c->time_limit = 0;
|
c->time_limit = 0;
|
||||||
@ -486,6 +475,7 @@ static PHP_METHOD(V8Js, __construct)
|
|||||||
c->object_name.Reset(isolate, object_name_js);
|
c->object_name.Reset(isolate, object_name_js);
|
||||||
|
|
||||||
/* Add the PHP object into global object */
|
/* Add the PHP object into global object */
|
||||||
|
php_obj_t->InstanceTemplate()->SetInternalFieldCount(2);
|
||||||
v8::Local<v8::Object> php_obj = php_obj_t->InstanceTemplate()->NewInstance();
|
v8::Local<v8::Object> php_obj = php_obj_t->InstanceTemplate()->NewInstance();
|
||||||
V8JS_GLOBAL(isolate)->ForceSet(object_name_js, php_obj, v8::ReadOnly);
|
V8JS_GLOBAL(isolate)->ForceSet(object_name_js, php_obj, v8::ReadOnly);
|
||||||
|
|
||||||
@ -516,7 +506,7 @@ static PHP_METHOD(V8Js, __construct)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Add pointer to zend object */
|
/* Add pointer to zend object */
|
||||||
php_obj->SetHiddenValue(V8JS_SYM(PHPJS_OBJECT_KEY), v8::External::New(isolate, getThis()));
|
php_obj->SetAlignedPointerInInternalField(1, getThis());
|
||||||
|
|
||||||
/* Export public methods */
|
/* Export public methods */
|
||||||
zend_function *method_ptr;
|
zend_function *method_ptr;
|
||||||
@ -1108,7 +1098,7 @@ static PHP_METHOD(V8Js, getExtensions)
|
|||||||
}
|
}
|
||||||
/* }}} */
|
/* }}} */
|
||||||
|
|
||||||
#if PHP_V8_API_VERSION >= 4003007
|
|
||||||
/* {{{ proto string|bool V8Js::createSnapshot(string embed_source)
|
/* {{{ proto string|bool V8Js::createSnapshot(string embed_source)
|
||||||
*/
|
*/
|
||||||
static PHP_METHOD(V8Js, createSnapshot)
|
static PHP_METHOD(V8Js, createSnapshot)
|
||||||
@ -1139,7 +1129,6 @@ static PHP_METHOD(V8Js, createSnapshot)
|
|||||||
delete[] snapshot_blob.data;
|
delete[] snapshot_blob.data;
|
||||||
}
|
}
|
||||||
/* }}} */
|
/* }}} */
|
||||||
#endif /* PHP_V8_API_VERSION >= 4003007 */
|
|
||||||
|
|
||||||
|
|
||||||
/* {{{ arginfo */
|
/* {{{ arginfo */
|
||||||
@ -1210,11 +1199,9 @@ ZEND_END_ARG_INFO()
|
|||||||
ZEND_BEGIN_ARG_INFO(arginfo_v8js_getextensions, 0)
|
ZEND_BEGIN_ARG_INFO(arginfo_v8js_getextensions, 0)
|
||||||
ZEND_END_ARG_INFO()
|
ZEND_END_ARG_INFO()
|
||||||
|
|
||||||
#if PHP_V8_API_VERSION >= 4003007
|
|
||||||
ZEND_BEGIN_ARG_INFO_EX(arginfo_v8js_createsnapshot, 0, 0, 1)
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_v8js_createsnapshot, 0, 0, 1)
|
||||||
ZEND_ARG_INFO(0, script)
|
ZEND_ARG_INFO(0, script)
|
||||||
ZEND_END_ARG_INFO()
|
ZEND_END_ARG_INFO()
|
||||||
#endif
|
|
||||||
|
|
||||||
ZEND_BEGIN_ARG_INFO_EX(arginfo_v8js_settimelimit, 0, 0, 1)
|
ZEND_BEGIN_ARG_INFO_EX(arginfo_v8js_settimelimit, 0, 0, 1)
|
||||||
ZEND_ARG_INFO(0, time_limit)
|
ZEND_ARG_INFO(0, time_limit)
|
||||||
@ -1242,10 +1229,7 @@ const zend_function_entry v8js_methods[] = { /* {{{ */
|
|||||||
PHP_ME(V8Js, setAverageObjectSize, arginfo_v8js_setaverageobjectsize, ZEND_ACC_PUBLIC)
|
PHP_ME(V8Js, setAverageObjectSize, arginfo_v8js_setaverageobjectsize, ZEND_ACC_PUBLIC)
|
||||||
PHP_ME(V8Js, registerExtension, arginfo_v8js_registerextension, ZEND_ACC_PUBLIC|ZEND_ACC_STATIC)
|
PHP_ME(V8Js, registerExtension, arginfo_v8js_registerextension, ZEND_ACC_PUBLIC|ZEND_ACC_STATIC)
|
||||||
PHP_ME(V8Js, getExtensions, arginfo_v8js_getextensions, ZEND_ACC_PUBLIC|ZEND_ACC_STATIC)
|
PHP_ME(V8Js, getExtensions, arginfo_v8js_getextensions, ZEND_ACC_PUBLIC|ZEND_ACC_STATIC)
|
||||||
|
|
||||||
#if PHP_V8_API_VERSION >= 4003007
|
|
||||||
PHP_ME(V8Js, createSnapshot, arginfo_v8js_createsnapshot, ZEND_ACC_PUBLIC|ZEND_ACC_STATIC)
|
PHP_ME(V8Js, createSnapshot, arginfo_v8js_createsnapshot, ZEND_ACC_PUBLIC|ZEND_ACC_STATIC)
|
||||||
#endif
|
|
||||||
{NULL, NULL, NULL}
|
{NULL, NULL, NULL}
|
||||||
};
|
};
|
||||||
/* }}} */
|
/* }}} */
|
||||||
@ -1314,11 +1298,6 @@ PHP_MINIT_FUNCTION(v8js_class) /* {{{ */
|
|||||||
|
|
||||||
le_v8js_script = zend_register_list_destructors_ex(v8js_script_dtor, NULL, PHP_V8JS_SCRIPT_RES_NAME, module_number);
|
le_v8js_script = zend_register_list_destructors_ex(v8js_script_dtor, NULL, PHP_V8JS_SCRIPT_RES_NAME, module_number);
|
||||||
|
|
||||||
#if PHP_V8_API_VERSION >= 4004010 && PHP_V8_API_VERSION < 4004044
|
|
||||||
static ArrayBufferAllocator array_buffer_allocator;
|
|
||||||
v8::V8::SetArrayBufferAllocator(&array_buffer_allocator);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return SUCCESS;
|
return SUCCESS;
|
||||||
} /* }}} */
|
} /* }}} */
|
||||||
|
|
||||||
|
@ -70,11 +70,9 @@ struct v8js_ctx {
|
|||||||
std::vector<struct _v8js_script *> script_objects;
|
std::vector<struct _v8js_script *> script_objects;
|
||||||
char *tz;
|
char *tz;
|
||||||
|
|
||||||
#if PHP_V8_API_VERSION >= 4003007
|
|
||||||
v8::Isolate::CreateParams create_params;
|
v8::Isolate::CreateParams create_params;
|
||||||
zval *zval_snapshot_blob;
|
zval *zval_snapshot_blob;
|
||||||
v8::StartupData snapshot_blob;
|
v8::StartupData snapshot_blob;
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef ZTS
|
#ifdef ZTS
|
||||||
void ***zts_ctx;
|
void ***zts_ctx;
|
||||||
|
@ -2,12 +2,13 @@
|
|||||||
+----------------------------------------------------------------------+
|
+----------------------------------------------------------------------+
|
||||||
| PHP Version 5 |
|
| PHP Version 5 |
|
||||||
+----------------------------------------------------------------------+
|
+----------------------------------------------------------------------+
|
||||||
| Copyright (c) 1997-2013 The PHP Group |
|
| Copyright (c) 1997-2016 The PHP Group |
|
||||||
+----------------------------------------------------------------------+
|
+----------------------------------------------------------------------+
|
||||||
| http://www.opensource.org/licenses/mit-license.php MIT License |
|
| http://www.opensource.org/licenses/mit-license.php MIT License |
|
||||||
+----------------------------------------------------------------------+
|
+----------------------------------------------------------------------+
|
||||||
| Author: Jani Taskinen <jani.taskinen@iki.fi> |
|
| Author: Jani Taskinen <jani.taskinen@iki.fi> |
|
||||||
| Author: Patrick Reilly <preilly@php.net> |
|
| Author: Patrick Reilly <preilly@php.net> |
|
||||||
|
| Author: Stefan Siegl <stesie@php.net> |
|
||||||
+----------------------------------------------------------------------+
|
+----------------------------------------------------------------------+
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -236,14 +237,15 @@ int v8js_to_zval(v8::Handle<v8::Value> jsValue, zval *return_value, int flags, v
|
|||||||
}
|
}
|
||||||
else if (jsValue->IsObject())
|
else if (jsValue->IsObject())
|
||||||
{
|
{
|
||||||
v8::Handle<v8::Object> self = v8::Handle<v8::Object>::Cast(jsValue);
|
v8::Local<v8::Object> self = jsValue->ToObject();
|
||||||
|
|
||||||
// if this is a wrapped PHP object, then just unwrap it.
|
// if this is a wrapped PHP object, then just unwrap it.
|
||||||
v8::Local<v8::Value> php_object = self->GetHiddenValue(V8JS_SYM(PHPJS_OBJECT_KEY));
|
if (self->InternalFieldCount()) {
|
||||||
if (!php_object.IsEmpty()) {
|
zval *object = reinterpret_cast<zval *>(self->GetAlignedPointerFromInternalField(1));
|
||||||
zval *object = reinterpret_cast<zval *>(v8::External::Cast(*php_object)->Value());
|
|
||||||
RETVAL_ZVAL(object, 1, 0);
|
RETVAL_ZVAL(object, 1, 0);
|
||||||
return SUCCESS;
|
return SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((flags & V8JS_FLAG_FORCE_ARRAY && !jsValue->IsFunction()) || jsValue->IsArray()) {
|
if ((flags & V8JS_FLAG_FORCE_ARRAY && !jsValue->IsFunction()) || jsValue->IsArray()) {
|
||||||
array_init(return_value);
|
array_init(return_value);
|
||||||
return v8js_get_properties_hash(jsValue, Z_ARRVAL_P(return_value), flags, isolate TSRMLS_CC);
|
return v8js_get_properties_hash(jsValue, Z_ARRVAL_P(return_value), flags, isolate TSRMLS_CC);
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
+----------------------------------------------------------------------+
|
+----------------------------------------------------------------------+
|
||||||
| PHP Version 5 |
|
| PHP Version 5 |
|
||||||
+----------------------------------------------------------------------+
|
+----------------------------------------------------------------------+
|
||||||
| Copyright (c) 1997-2015 The PHP Group |
|
| Copyright (c) 1997-2016 The PHP Group |
|
||||||
+----------------------------------------------------------------------+
|
+----------------------------------------------------------------------+
|
||||||
| http://www.opensource.org/licenses/mit-license.php MIT License |
|
| http://www.opensource.org/licenses/mit-license.php MIT License |
|
||||||
+----------------------------------------------------------------------+
|
+----------------------------------------------------------------------+
|
||||||
@ -83,12 +83,8 @@ void v8js_create_script_exception(zval *return_value, v8::Isolate *isolate, v8::
|
|||||||
PHPV8_EXPROP(_string, JsTrace, stacktrace_string);
|
PHPV8_EXPROP(_string, JsTrace, stacktrace_string);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(try_catch->Exception()->IsObject()) {
|
if(try_catch->Exception()->IsObject() && try_catch->Exception()->ToObject()->InternalFieldCount()) {
|
||||||
v8::Local<v8::Value> php_ref = try_catch->Exception()->ToObject()->GetHiddenValue(V8JS_SYM(PHPJS_OBJECT_KEY));
|
zval *php_exception = reinterpret_cast<zval *>(try_catch->Exception()->ToObject()->GetAlignedPointerFromInternalField(1));
|
||||||
|
|
||||||
if(!php_ref.IsEmpty()) {
|
|
||||||
assert(php_ref->IsExternal());
|
|
||||||
zval *php_exception = reinterpret_cast<zval *>(v8::External::Cast(*php_ref)->Value());
|
|
||||||
|
|
||||||
zend_class_entry *exception_ce = zend_exception_get_default(TSRMLS_C);
|
zend_class_entry *exception_ce = zend_exception_get_default(TSRMLS_C);
|
||||||
if (Z_TYPE_P(php_exception) == IS_OBJECT && instanceof_function(Z_OBJCE_P(php_exception), exception_ce TSRMLS_CC)) {
|
if (Z_TYPE_P(php_exception) == IS_OBJECT && instanceof_function(Z_OBJCE_P(php_exception), exception_ce TSRMLS_CC)) {
|
||||||
@ -96,7 +92,6 @@ void v8js_create_script_exception(zval *return_value, v8::Isolate *isolate, v8::
|
|||||||
zend_exception_set_previous(return_value, php_exception TSRMLS_CC);
|
zend_exception_set_previous(return_value, php_exception TSRMLS_CC);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,12 +2,13 @@
|
|||||||
+----------------------------------------------------------------------+
|
+----------------------------------------------------------------------+
|
||||||
| PHP Version 5 |
|
| PHP Version 5 |
|
||||||
+----------------------------------------------------------------------+
|
+----------------------------------------------------------------------+
|
||||||
| Copyright (c) 1997-2013 The PHP Group |
|
| Copyright (c) 1997-2016 The PHP Group |
|
||||||
+----------------------------------------------------------------------+
|
+----------------------------------------------------------------------+
|
||||||
| http://www.opensource.org/licenses/mit-license.php MIT License |
|
| http://www.opensource.org/licenses/mit-license.php MIT License |
|
||||||
+----------------------------------------------------------------------+
|
+----------------------------------------------------------------------+
|
||||||
| Author: Jani Taskinen <jani.taskinen@iki.fi> |
|
| Author: Jani Taskinen <jani.taskinen@iki.fi> |
|
||||||
| Author: Patrick Reilly <preilly@php.net> |
|
| Author: Patrick Reilly <preilly@php.net> |
|
||||||
|
| Author: Stefan Siegl <stesie@php.net> |
|
||||||
+----------------------------------------------------------------------+
|
+----------------------------------------------------------------------+
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -29,7 +30,7 @@ extern "C" {
|
|||||||
#include "v8js_object_export.h"
|
#include "v8js_object_export.h"
|
||||||
#include "v8js_v8object_class.h"
|
#include "v8js_v8object_class.h"
|
||||||
|
|
||||||
static void v8js_weak_object_callback(const v8::WeakCallbackData<v8::Object, zval> &data);
|
static void v8js_weak_object_callback(const v8::WeakCallbackInfo<zval> &data);
|
||||||
|
|
||||||
/* Callback for PHP methods and functions */
|
/* Callback for PHP methods and functions */
|
||||||
static void v8js_call_php_func(zval *value, zend_class_entry *ce, zend_function *method_ptr, v8::Isolate *isolate, const v8::FunctionCallbackInfo<v8::Value>& info TSRMLS_DC) /* {{{ */
|
static void v8js_call_php_func(zval *value, zend_class_entry *ce, zend_function *method_ptr, v8::Isolate *isolate, const v8::FunctionCallbackInfo<v8::Value>& info TSRMLS_DC) /* {{{ */
|
||||||
@ -88,13 +89,9 @@ static void v8js_call_php_func(zval *value, zend_class_entry *ce, zend_function
|
|||||||
fci.params = (zval ***) safe_emalloc(argc, sizeof(zval **), 0);
|
fci.params = (zval ***) safe_emalloc(argc, sizeof(zval **), 0);
|
||||||
argv = (zval **) safe_emalloc(argc, sizeof(zval *), 0);
|
argv = (zval **) safe_emalloc(argc, sizeof(zval *), 0);
|
||||||
for (i = 0; i < argc; i++) {
|
for (i = 0; i < argc; i++) {
|
||||||
v8::Local<v8::Value> php_object;
|
if (info[i]->IsObject() && info[i]->ToObject()->InternalFieldCount()) {
|
||||||
if (info[i]->IsObject()) {
|
|
||||||
php_object = v8::Local<v8::Object>::Cast(info[i])->GetHiddenValue(V8JS_SYM(PHPJS_OBJECT_KEY));
|
|
||||||
}
|
|
||||||
if (!php_object.IsEmpty()) {
|
|
||||||
/* This is a PHP object, passed to JS and back. */
|
/* This is a PHP object, passed to JS and back. */
|
||||||
argv[i] = reinterpret_cast<zval *>(v8::External::Cast(*php_object)->Value());
|
argv[i] = reinterpret_cast<zval *>(info[i]->ToObject()->GetAlignedPointerFromInternalField(1));
|
||||||
Z_ADDREF_P(argv[i]);
|
Z_ADDREF_P(argv[i]);
|
||||||
} else {
|
} else {
|
||||||
MAKE_STD_ZVAL(argv[i]);
|
MAKE_STD_ZVAL(argv[i]);
|
||||||
@ -178,7 +175,7 @@ void v8js_php_callback(const v8::FunctionCallbackInfo<v8::Value>& info) /* {{{ *
|
|||||||
v8::Local<v8::Object> self = info.Holder();
|
v8::Local<v8::Object> self = info.Holder();
|
||||||
|
|
||||||
V8JS_TSRMLS_FETCH();
|
V8JS_TSRMLS_FETCH();
|
||||||
zval *value = reinterpret_cast<zval *>(v8::External::Cast(*self->GetHiddenValue(V8JS_SYM(PHPJS_OBJECT_KEY)))->Value());
|
zval *value = reinterpret_cast<zval *>(self->GetAlignedPointerFromInternalField(1));
|
||||||
zend_function *method_ptr;
|
zend_function *method_ptr;
|
||||||
zend_class_entry *ce = Z_OBJCE_P(value);
|
zend_class_entry *ce = Z_OBJCE_P(value);
|
||||||
|
|
||||||
@ -198,9 +195,7 @@ static void v8js_construct_callback(const v8::FunctionCallbackInfo<v8::Value>& i
|
|||||||
v8::Isolate *isolate = info.GetIsolate();
|
v8::Isolate *isolate = info.GetIsolate();
|
||||||
info.GetReturnValue().Set(V8JS_UNDEFINED);
|
info.GetReturnValue().Set(V8JS_UNDEFINED);
|
||||||
|
|
||||||
// @todo assert constructor call
|
|
||||||
v8::Handle<v8::Object> newobj = info.This();
|
v8::Handle<v8::Object> newobj = info.This();
|
||||||
v8::Local<v8::External> php_object;
|
|
||||||
zval *value;
|
zval *value;
|
||||||
|
|
||||||
if (!info.IsConstructCall()) {
|
if (!info.IsConstructCall()) {
|
||||||
@ -215,14 +210,14 @@ static void v8js_construct_callback(const v8::FunctionCallbackInfo<v8::Value>& i
|
|||||||
|
|
||||||
if (info[0]->IsExternal()) {
|
if (info[0]->IsExternal()) {
|
||||||
// Object created by v8js in v8js_hash_to_jsobj, PHP object passed as v8::External.
|
// Object created by v8js in v8js_hash_to_jsobj, PHP object passed as v8::External.
|
||||||
php_object = v8::Local<v8::External>::Cast(info[0]);
|
v8::Local<v8::External> php_object = v8::Local<v8::External>::Cast(info[0]);
|
||||||
value = reinterpret_cast<zval *>(php_object->Value());
|
value = reinterpret_cast<zval *>(php_object->Value());
|
||||||
|
|
||||||
if(ctx->weak_objects.count(value)) {
|
if(ctx->weak_objects.count(value)) {
|
||||||
// We already exported this object, hence no need to add another
|
// We already exported this object, hence no need to add another
|
||||||
// ref, v8 won't give us a second weak-object callback anyways.
|
// ref, v8 won't give us a second weak-object callback anyways.
|
||||||
newobj->SetAlignedPointerInInternalField(0, ext_tmpl->Value());
|
newobj->SetAlignedPointerInInternalField(0, ext_tmpl->Value());
|
||||||
newobj->SetHiddenValue(V8JS_SYM(PHPJS_OBJECT_KEY), php_object);
|
newobj->SetAlignedPointerInInternalField(1, value);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -248,17 +243,16 @@ static void v8js_construct_callback(const v8::FunctionCallbackInfo<v8::Value>& i
|
|||||||
if (ctor_ptr != NULL) {
|
if (ctor_ptr != NULL) {
|
||||||
v8js_call_php_func(value, ce, ctor_ptr, isolate, info TSRMLS_CC);
|
v8js_call_php_func(value, ce, ctor_ptr, isolate, info TSRMLS_CC);
|
||||||
}
|
}
|
||||||
php_object = v8::External::New(isolate, value);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
newobj->SetAlignedPointerInInternalField(0, ext_tmpl->Value());
|
newobj->SetAlignedPointerInInternalField(0, ext_tmpl->Value());
|
||||||
newobj->SetHiddenValue(V8JS_SYM(PHPJS_OBJECT_KEY), php_object);
|
newobj->SetAlignedPointerInInternalField(1, value);
|
||||||
|
|
||||||
// Since we got to decrease the reference count again, in case v8 garbage collector
|
// Since we got to decrease the reference count again, in case v8 garbage collector
|
||||||
// decides to dispose the JS object, we add a weak persistent handle and register
|
// decides to dispose the JS object, we add a weak persistent handle and register
|
||||||
// a callback function that removes the reference.
|
// a callback function that removes the reference.
|
||||||
ctx->weak_objects[value].Reset(isolate, newobj);
|
ctx->weak_objects[value].Reset(isolate, newobj);
|
||||||
ctx->weak_objects[value].SetWeak(value, v8js_weak_object_callback);
|
ctx->weak_objects[value].SetWeak(value, v8js_weak_object_callback, v8::WeakCallbackType::kParameter);
|
||||||
|
|
||||||
// Just tell v8 that we're allocating some external memory
|
// Just tell v8 that we're allocating some external memory
|
||||||
// (for the moment we just always tell 1k instead of trying to find out actual values)
|
// (for the moment we just always tell 1k instead of trying to find out actual values)
|
||||||
@ -267,7 +261,7 @@ static void v8js_construct_callback(const v8::FunctionCallbackInfo<v8::Value>& i
|
|||||||
/* }}} */
|
/* }}} */
|
||||||
|
|
||||||
|
|
||||||
static void v8js_weak_object_callback(const v8::WeakCallbackData<v8::Object, zval> &data) {
|
static void v8js_weak_object_callback(const v8::WeakCallbackInfo<zval> &data) {
|
||||||
v8::Isolate *isolate = data.GetIsolate();
|
v8::Isolate *isolate = data.GetIsolate();
|
||||||
|
|
||||||
zval *value = data.GetParameter();
|
zval *value = data.GetParameter();
|
||||||
@ -281,7 +275,7 @@ static void v8js_weak_object_callback(const v8::WeakCallbackData<v8::Object, zva
|
|||||||
isolate->AdjustAmountOfExternalAllocatedMemory(-ctx->average_object_size);
|
isolate->AdjustAmountOfExternalAllocatedMemory(-ctx->average_object_size);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void v8js_weak_closure_callback(const v8::WeakCallbackData<v8::Object, v8js_tmpl_t> &data) {
|
static void v8js_weak_closure_callback(const v8::WeakCallbackInfo<v8js_tmpl_t> &data) {
|
||||||
v8::Isolate *isolate = data.GetIsolate();
|
v8::Isolate *isolate = data.GetIsolate();
|
||||||
|
|
||||||
v8js_tmpl_t *persist_tpl_ = data.GetParameter();
|
v8js_tmpl_t *persist_tpl_ = data.GetParameter();
|
||||||
@ -319,7 +313,7 @@ static void v8js_named_property_enumerator(const v8::PropertyCallbackInfo<v8::Ar
|
|||||||
uint key_len;
|
uint key_len;
|
||||||
ulong index;
|
ulong index;
|
||||||
|
|
||||||
zval *object = reinterpret_cast<zval *>(v8::External::Cast(*self->GetHiddenValue(V8JS_SYM(PHPJS_OBJECT_KEY)))->Value());
|
zval *object = reinterpret_cast<zval *>(self->GetAlignedPointerFromInternalField(1));
|
||||||
ce = Z_OBJCE_P(object);
|
ce = Z_OBJCE_P(object);
|
||||||
|
|
||||||
/* enumerate all methods */
|
/* enumerate all methods */
|
||||||
@ -449,7 +443,7 @@ static void v8js_fake_call_impl(const v8::FunctionCallbackInfo<v8::Value>& info)
|
|||||||
|
|
||||||
V8JS_TSRMLS_FETCH();
|
V8JS_TSRMLS_FETCH();
|
||||||
zend_class_entry *ce;
|
zend_class_entry *ce;
|
||||||
zval *object = reinterpret_cast<zval *>(v8::External::Cast(*self->GetHiddenValue(V8JS_SYM(PHPJS_OBJECT_KEY)))->Value());
|
zval *object = reinterpret_cast<zval *>(self->GetAlignedPointerFromInternalField(1));
|
||||||
ce = Z_OBJCE_P(object);
|
ce = Z_OBJCE_P(object);
|
||||||
|
|
||||||
// first arg is method name, second arg is array of args.
|
// first arg is method name, second arg is array of args.
|
||||||
@ -541,7 +535,7 @@ inline v8::Local<v8::Value> v8js_named_property_callback(v8::Local<v8::String> p
|
|||||||
zend_function *method_ptr = NULL;
|
zend_function *method_ptr = NULL;
|
||||||
zval *php_value;
|
zval *php_value;
|
||||||
|
|
||||||
zval *object = reinterpret_cast<zval *>(v8::External::Cast(*self->GetHiddenValue(V8JS_SYM(PHPJS_OBJECT_KEY)))->Value());
|
zval *object = reinterpret_cast<zval *>(self->GetAlignedPointerFromInternalField(1));
|
||||||
v8js_tmpl_t *tmpl_ptr = reinterpret_cast<v8js_tmpl_t *>(self->GetAlignedPointerFromInternalField(0));
|
v8js_tmpl_t *tmpl_ptr = reinterpret_cast<v8js_tmpl_t *>(self->GetAlignedPointerFromInternalField(0));
|
||||||
v8::Local<v8::FunctionTemplate> tmpl = v8::Local<v8::FunctionTemplate>::New(isolate, *tmpl_ptr);
|
v8::Local<v8::FunctionTemplate> tmpl = v8::Local<v8::FunctionTemplate>::New(isolate, *tmpl_ptr);
|
||||||
ce = scope = Z_OBJCE_P(object);
|
ce = scope = Z_OBJCE_P(object);
|
||||||
@ -809,7 +803,7 @@ static v8::Handle<v8::Object> v8js_wrap_object(v8::Isolate *isolate, zend_class_
|
|||||||
new_tpl = v8::FunctionTemplate::New(isolate, 0);
|
new_tpl = v8::FunctionTemplate::New(isolate, 0);
|
||||||
|
|
||||||
new_tpl->SetClassName(V8JS_STRL(ce->name, ce->name_length));
|
new_tpl->SetClassName(V8JS_STRL(ce->name, ce->name_length));
|
||||||
new_tpl->InstanceTemplate()->SetInternalFieldCount(1);
|
new_tpl->InstanceTemplate()->SetInternalFieldCount(2);
|
||||||
|
|
||||||
if (ce == zend_ce_closure) {
|
if (ce == zend_ce_closure) {
|
||||||
/* Got a closure, mustn't cache ... */
|
/* Got a closure, mustn't cache ... */
|
||||||
@ -890,7 +884,7 @@ static v8::Handle<v8::Object> v8js_wrap_object(v8::Isolate *isolate, zend_class_
|
|||||||
if (ce == zend_ce_closure) {
|
if (ce == zend_ce_closure) {
|
||||||
// free uncached function template when object is freed
|
// free uncached function template when object is freed
|
||||||
ctx->weak_closures[persist_tpl_].Reset(isolate, newobj);
|
ctx->weak_closures[persist_tpl_].Reset(isolate, newobj);
|
||||||
ctx->weak_closures[persist_tpl_].SetWeak(persist_tpl_, v8js_weak_closure_callback);
|
ctx->weak_closures[persist_tpl_].SetWeak(persist_tpl_, v8js_weak_closure_callback, v8::WeakCallbackType::kParameter);
|
||||||
}
|
}
|
||||||
|
|
||||||
return newobj;
|
return newobj;
|
||||||
|
55
v8js_v8.cc
55
v8js_v8.cc
@ -25,7 +25,7 @@ extern "C" {
|
|||||||
#include "zend_exceptions.h"
|
#include "zend_exceptions.h"
|
||||||
}
|
}
|
||||||
|
|
||||||
#if !defined(_WIN32) && PHP_V8_API_VERSION >= 3029036
|
#if !defined(_WIN32)
|
||||||
#include <libplatform/libplatform.h>
|
#include <libplatform/libplatform.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
@ -34,43 +34,6 @@ extern "C" {
|
|||||||
#include "v8js_timer.h"
|
#include "v8js_timer.h"
|
||||||
#include "v8js_exceptions.h"
|
#include "v8js_exceptions.h"
|
||||||
|
|
||||||
#if defined(PHP_V8_USE_EXTERNAL_STARTUP_DATA) && PHP_V8_API_VERSION < 4006076
|
|
||||||
/* Old V8 version, requires startup data but has no
|
|
||||||
* (internal/API) means to let it be loaded. */
|
|
||||||
static v8::StartupData natives_;
|
|
||||||
static v8::StartupData snapshot_;
|
|
||||||
|
|
||||||
static void v8js_v8_load_startup_data(const char* blob_file,
|
|
||||||
v8::StartupData* startup_data,
|
|
||||||
void (*setter_fn)(v8::StartupData*)) {
|
|
||||||
startup_data->data = NULL;
|
|
||||||
startup_data->raw_size = 0;
|
|
||||||
|
|
||||||
if (!blob_file) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
FILE* file = fopen(blob_file, "rb");
|
|
||||||
if (!file) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
fseek(file, 0, SEEK_END);
|
|
||||||
startup_data->raw_size = static_cast<int>(ftell(file));
|
|
||||||
rewind(file);
|
|
||||||
|
|
||||||
startup_data->data = new char[startup_data->raw_size];
|
|
||||||
int read_size = static_cast<int>(fread(const_cast<char*>(startup_data->data),
|
|
||||||
1, startup_data->raw_size, file));
|
|
||||||
fclose(file);
|
|
||||||
|
|
||||||
if (startup_data->raw_size == read_size) {
|
|
||||||
(*setter_fn)(startup_data);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
void v8js_v8_init(TSRMLS_D) /* {{{ */
|
void v8js_v8_init(TSRMLS_D) /* {{{ */
|
||||||
{
|
{
|
||||||
/* Run only once; thread-local test first */
|
/* Run only once; thread-local test first */
|
||||||
@ -93,21 +56,14 @@ void v8js_v8_init(TSRMLS_D) /* {{{ */
|
|||||||
|
|
||||||
#ifdef PHP_V8_USE_EXTERNAL_STARTUP_DATA
|
#ifdef PHP_V8_USE_EXTERNAL_STARTUP_DATA
|
||||||
/* V8 doesn't work without startup data, load it. */
|
/* V8 doesn't work without startup data, load it. */
|
||||||
#if PHP_V8_API_VERSION >= 4006076
|
|
||||||
v8::V8::InitializeExternalStartupData(
|
v8::V8::InitializeExternalStartupData(
|
||||||
PHP_V8_NATIVES_BLOB_PATH,
|
PHP_V8_NATIVES_BLOB_PATH,
|
||||||
PHP_V8_SNAPSHOT_BLOB_PATH
|
PHP_V8_SNAPSHOT_BLOB_PATH
|
||||||
);
|
);
|
||||||
#else
|
|
||||||
v8js_v8_load_startup_data(PHP_V8_NATIVES_BLOB_PATH, &natives_, v8::V8::SetNativesDataBlob);
|
|
||||||
v8js_v8_load_startup_data(PHP_V8_SNAPSHOT_BLOB_PATH, &snapshot_, v8::V8::SetSnapshotDataBlob);
|
|
||||||
#endif
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if !defined(_WIN32) && PHP_V8_API_VERSION >= 3029036
|
|
||||||
v8js_process_globals.v8_platform = v8::platform::CreateDefaultPlatform();
|
v8js_process_globals.v8_platform = v8::platform::CreateDefaultPlatform();
|
||||||
v8::V8::InitializePlatform(v8js_process_globals.v8_platform);
|
v8::V8::InitializePlatform(v8js_process_globals.v8_platform);
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Set V8 command line flags (must be done before V8::Initialize()!) */
|
/* Set V8 command line flags (must be done before V8::Initialize()!) */
|
||||||
if (v8js_process_globals.v8_flags) {
|
if (v8js_process_globals.v8_flags) {
|
||||||
@ -320,13 +276,8 @@ int v8js_get_properties_hash(v8::Handle<v8::Value> jsValue, HashTable *retval, i
|
|||||||
const char *key = ToCString(cstr);
|
const char *key = ToCString(cstr);
|
||||||
zval *value = NULL;
|
zval *value = NULL;
|
||||||
|
|
||||||
v8::Local<v8::Value> php_object;
|
if (jsVal->IsObject() && jsVal->ToObject()->InternalFieldCount()) {
|
||||||
if (jsVal->IsObject()) {
|
value = reinterpret_cast<zval *>(jsVal->ToObject()->GetAlignedPointerFromInternalField(1));
|
||||||
php_object = v8::Local<v8::Object>::Cast(jsVal)->GetHiddenValue(V8JS_SYM(PHPJS_OBJECT_KEY));
|
|
||||||
}
|
|
||||||
if (!php_object.IsEmpty()) {
|
|
||||||
/* This is a PHP object, passed to JS and back. */
|
|
||||||
value = reinterpret_cast<zval *>(v8::External::Cast(*php_object)->Value());
|
|
||||||
Z_ADDREF_P(value);
|
Z_ADDREF_P(value);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
Loading…
Reference in New Issue
Block a user