0
0
mirror of https://github.com/phpv8/v8js.git synced 2025-01-18 15:01:54 +00:00

Merge remote-tracking branch 'origin/master' into php7

This commit is contained in:
Stefan Siegl 2016-07-02 22:59:33 +02:00
commit c459acd1ef
24 changed files with 80 additions and 4 deletions

View File

@ -31,6 +31,9 @@ Compile latest V8
``` ```
# Install `build-essential` if you haven't already:
sudo apt-get install build-essential
# Install `libicu-dev` if you haven't already: # Install `libicu-dev` if you haven't already:
sudo apt-get install libicu-dev sudo apt-get install libicu-dev

View File

@ -700,5 +700,20 @@ Code Cleanup
- Removed old examples and pre-phpt test script - Removed old examples and pre-phpt test script
</notes> </notes>
</release> </release>
<release>
<version>
<release>0.6.4</release>
<api>0.6.4</api>
</version>
<stability>
<release>stable</release>
<api>stable</api>
</stability>
<date>2016-07-02</date>
<license uri="http://www.php.net/license">The MIT License (MIT)</license>
<notes>
Fix build against V8 5.3.337 (and higher)
</notes>
</release>
</changelog> </changelog>
</package> </package>

View File

@ -25,6 +25,7 @@ extern zend_module_entry v8js_module_entry;
* Local variables: * Local variables:
* tab-width: 4 * tab-width: 4
* c-basic-offset: 4 * c-basic-offset: 4
* indent-tabs-mode: t
* End: * End:
* vim600: noet sw=4 ts=4 fdm=marker * vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4 * vim<600: noet sw=4 ts=4

View File

@ -172,6 +172,7 @@ void v8js_register_methods(v8::Handle<v8::ObjectTemplate>, v8js_ctx *c);
* Local variables: * Local variables:
* tab-width: 4 * tab-width: 4
* c-basic-offset: 4 * c-basic-offset: 4
* indent-tabs-mode: t
* End: * End:
* vim600: noet sw=4 ts=4 fdm=marker * vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4 * vim<600: noet sw=4 ts=4

View File

@ -279,6 +279,7 @@ zend_module_entry v8js_module_entry = {
* Local variables: * Local variables:
* tab-width: 4 * tab-width: 4
* c-basic-offset: 4 * c-basic-offset: 4
* indent-tabs-mode: t
* End: * End:
* vim600: noet sw=4 ts=4 fdm=marker * vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4 * vim<600: noet sw=4 ts=4

View File

@ -255,6 +255,7 @@ void v8js_array_access_named_getter(v8::Local<v8::String> property, const v8::Pr
* Local variables: * Local variables:
* tab-width: 4 * tab-width: 4
* c-basic-offset: 4 * c-basic-offset: 4
* indent-tabs-mode: t
* End: * End:
* vim600: noet sw=4 ts=4 fdm=marker * vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4 * vim<600: noet sw=4 ts=4

View File

@ -29,3 +29,13 @@ void v8js_array_access_named_getter(v8::Local<v8::String> property,
const v8::PropertyCallbackInfo<v8::Value> &info); const v8::PropertyCallbackInfo<v8::Value> &info);
#endif /* V8JS_ARRAY_ACCESS_H */ #endif /* V8JS_ARRAY_ACCESS_H */
/*
* Local variables:
* tab-width: 4
* c-basic-offset: 4
* indent-tabs-mode: t
* End:
* vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4
*/

View File

@ -1266,6 +1266,7 @@ PHP_MINIT_FUNCTION(v8js_class) /* {{{ */
* Local variables: * Local variables:
* tab-width: 4 * tab-width: 4
* c-basic-offset: 4 * c-basic-offset: 4
* indent-tabs-mode: t
* End: * End:
* vim600: noet sw=4 ts=4 fdm=marker * vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4 * vim<600: noet sw=4 ts=4

View File

@ -103,6 +103,7 @@ PHP_MINIT_FUNCTION(v8js_class);
* Local variables: * Local variables:
* tab-width: 4 * tab-width: 4
* c-basic-offset: 4 * c-basic-offset: 4
* indent-tabs-mode: t
* End: * End:
* vim600: noet sw=4 ts=4 fdm=marker * vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4 * vim<600: noet sw=4 ts=4

View File

@ -108,3 +108,13 @@ void v8js_commonjs_normalise_identifier(const char *base, const char *identifier
efree(term); efree(term);
} }
} }
/*
* Local variables:
* tab-width: 4
* c-basic-offset: 4
* indent-tabs-mode: t
* End:
* vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4
*/

View File

@ -16,3 +16,13 @@
void v8js_commonjs_normalise_identifier(const char *base, const char *identifier, char *normalised_path, char *module_name); void v8js_commonjs_normalise_identifier(const char *base, const char *identifier, char *normalised_path, char *module_name);
#endif /* V8JS_COMMONJS_H */ #endif /* V8JS_COMMONJS_H */
/*
* Local variables:
* tab-width: 4
* c-basic-offset: 4
* indent-tabs-mode: t
* End:
* vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4
*/

View File

@ -227,7 +227,7 @@ int v8js_to_zval(v8::Handle<v8::Value> jsValue, zval *return_value, int flags, v
v8::Local<v8::Object> self = jsValue->ToObject(); 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.
if (self->InternalFieldCount()) { if (self->InternalFieldCount() == 2) {
zend_object *object = reinterpret_cast<zend_object *>(self->GetAlignedPointerFromInternalField(1)); zend_object *object = reinterpret_cast<zend_object *>(self->GetAlignedPointerFromInternalField(1));
zval zval_object; zval zval_object;
ZVAL_OBJ(&zval_object, object); ZVAL_OBJ(&zval_object, object);
@ -256,6 +256,7 @@ int v8js_to_zval(v8::Handle<v8::Value> jsValue, zval *return_value, int flags, v
* Local variables: * Local variables:
* tab-width: 4 * tab-width: 4
* c-basic-offset: 4 * c-basic-offset: 4
* indent-tabs-mode: t
* End: * End:
* vim600: noet sw=4 ts=4 fdm=marker * vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4 * vim<600: noet sw=4 ts=4

View File

@ -81,7 +81,7 @@ 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() && try_catch->Exception()->ToObject()->InternalFieldCount()) { if(try_catch->Exception()->IsObject() && try_catch->Exception()->ToObject()->InternalFieldCount() == 2) {
zend_object *php_exception = reinterpret_cast<zend_object *>(try_catch->Exception()->ToObject()->GetAlignedPointerFromInternalField(1)); zend_object *php_exception = reinterpret_cast<zend_object *>(try_catch->Exception()->ToObject()->GetAlignedPointerFromInternalField(1));
zend_class_entry *exception_ce = zend_exception_get_default(TSRMLS_C); zend_class_entry *exception_ce = zend_exception_get_default(TSRMLS_C);
@ -245,6 +245,7 @@ PHP_MINIT_FUNCTION(v8js_exceptions) /* {{{ */
* Local variables: * Local variables:
* tab-width: 4 * tab-width: 4
* c-basic-offset: 4 * c-basic-offset: 4
* indent-tabs-mode: t
* End: * End:
* vim600: noet sw=4 ts=4 fdm=marker * vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4 * vim<600: noet sw=4 ts=4

View File

@ -31,6 +31,7 @@ PHP_MINIT_FUNCTION(v8js_exceptions);
* Local variables: * Local variables:
* tab-width: 4 * tab-width: 4
* c-basic-offset: 4 * c-basic-offset: 4
* indent-tabs-mode: t
* End: * End:
* vim600: noet sw=4 ts=4 fdm=marker * vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4 * vim<600: noet sw=4 ts=4

View File

@ -512,6 +512,7 @@ void v8js_register_methods(v8::Handle<v8::ObjectTemplate> global, v8js_ctx *c) /
* Local variables: * Local variables:
* tab-width: 4 * tab-width: 4
* c-basic-offset: 4 * c-basic-offset: 4
* indent-tabs-mode: t
* End: * End:
* vim600: noet sw=4 ts=4 fdm=marker * vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4 * vim<600: noet sw=4 ts=4

View File

@ -89,7 +89,7 @@ static void v8js_call_php_func(zend_object *object, zend_function *method_ptr, v
if (argc) { if (argc) {
fci.params = (zval *) safe_emalloc(argc, sizeof(zval), 0); fci.params = (zval *) safe_emalloc(argc, sizeof(zval), 0);
for (i = 0; i < argc; i++) { for (i = 0; i < argc; i++) {
if (info[i]->IsObject() && info[i]->ToObject()->InternalFieldCount()) { if (info[i]->IsObject() && info[i]->ToObject()->InternalFieldCount() == 2) {
/* This is a PHP object, passed to JS and back. */ /* This is a PHP object, passed to JS and back. */
zend_object *object = reinterpret_cast<zend_object *>(info[i]->ToObject()->GetAlignedPointerFromInternalField(1)); zend_object *object = reinterpret_cast<zend_object *>(info[i]->ToObject()->GetAlignedPointerFromInternalField(1));
ZVAL_OBJ(&fci.params[i], object); ZVAL_OBJ(&fci.params[i], object);
@ -964,6 +964,7 @@ v8::Handle<v8::Value> v8js_hash_to_jsobj(zval *value, v8::Isolate *isolate TSRML
* Local variables: * Local variables:
* tab-width: 4 * tab-width: 4
* c-basic-offset: 4 * c-basic-offset: 4
* indent-tabs-mode: t
* End: * End:
* vim600: noet sw=4 ts=4 fdm=marker * vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4 * vim<600: noet sw=4 ts=4

View File

@ -33,3 +33,13 @@ v8::Local<v8::Value> v8js_named_property_callback(v8::Local<v8::String> property
void v8js_php_callback(const v8::FunctionCallbackInfo<v8::Value>& info); void v8js_php_callback(const v8::FunctionCallbackInfo<v8::Value>& info);
#endif /* V8JS_OBJECT_EXPORT_H */ #endif /* V8JS_OBJECT_EXPORT_H */
/*
* Local variables:
* tab-width: 4
* c-basic-offset: 4
* indent-tabs-mode: t
* End:
* vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4
*/

View File

@ -151,6 +151,7 @@ void v8js_timer_push(long time_limit, long memory_limit, v8js_ctx *c TSRMLS_DC)
* Local variables: * Local variables:
* tab-width: 4 * tab-width: 4
* c-basic-offset: 4 * c-basic-offset: 4
* indent-tabs-mode: t
* End: * End:
* vim600: noet sw=4 ts=4 fdm=marker * vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4 * vim<600: noet sw=4 ts=4

View File

@ -33,6 +33,7 @@ void v8js_timer_push(long time_limit, long memory_limit, v8js_ctx *c TSRMLS_DC);
* Local variables: * Local variables:
* tab-width: 4 * tab-width: 4
* c-basic-offset: 4 * c-basic-offset: 4
* indent-tabs-mode: t
* End: * End:
* vim600: noet sw=4 ts=4 fdm=marker * vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4 * vim<600: noet sw=4 ts=4

View File

@ -274,7 +274,7 @@ int v8js_get_properties_hash(v8::Handle<v8::Value> jsValue, HashTable *retval, i
zval value; zval value;
ZVAL_UNDEF(&value); ZVAL_UNDEF(&value);
if (jsVal->IsObject() && jsVal->ToObject()->InternalFieldCount()) { if (jsVal->IsObject() && jsVal->ToObject()->InternalFieldCount() == 2) {
/* This is a PHP object, passed to JS and back. */ /* This is a PHP object, passed to JS and back. */
zend_object *object = reinterpret_cast<zend_object *>(jsVal->ToObject()->GetAlignedPointerFromInternalField(1)); zend_object *object = reinterpret_cast<zend_object *>(jsVal->ToObject()->GetAlignedPointerFromInternalField(1));
ZVAL_OBJ(&value, object); ZVAL_OBJ(&value, object);
@ -308,6 +308,7 @@ int v8js_get_properties_hash(v8::Handle<v8::Value> jsValue, HashTable *retval, i
* Local variables: * Local variables:
* tab-width: 4 * tab-width: 4
* c-basic-offset: 4 * c-basic-offset: 4
* indent-tabs-mode: t
* End: * End:
* vim600: noet sw=4 ts=4 fdm=marker * vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4 * vim<600: noet sw=4 ts=4

View File

@ -82,6 +82,7 @@ int v8js_get_properties_hash(v8::Handle<v8::Value> jsValue, HashTable *retval, i
* Local variables: * Local variables:
* tab-width: 4 * tab-width: 4
* c-basic-offset: 4 * c-basic-offset: 4
* indent-tabs-mode: t
* End: * End:
* vim600: noet sw=4 ts=4 fdm=marker * vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4 * vim<600: noet sw=4 ts=4

View File

@ -784,6 +784,7 @@ PHP_MINIT_FUNCTION(v8js_v8object_class) /* {{{ */
* Local variables: * Local variables:
* tab-width: 4 * tab-width: 4
* c-basic-offset: 4 * c-basic-offset: 4
* indent-tabs-mode: t
* End: * End:
* vim600: noet sw=4 ts=4 fdm=marker * vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4 * vim<600: noet sw=4 ts=4

View File

@ -65,6 +65,7 @@ PHP_MINIT_FUNCTION(v8js_v8object_class);
* Local variables: * Local variables:
* tab-width: 4 * tab-width: 4
* c-basic-offset: 4 * c-basic-offset: 4
* indent-tabs-mode: t
* End: * End:
* vim600: noet sw=4 ts=4 fdm=marker * vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4 * vim<600: noet sw=4 ts=4

View File

@ -84,6 +84,7 @@ void v8js_register_accessors(std::vector<v8js_accessor_ctx*> *accessor_list, v8:
* Local variables: * Local variables:
* tab-width: 4 * tab-width: 4
* c-basic-offset: 4 * c-basic-offset: 4
* indent-tabs-mode: t
* End: * End:
* vim600: noet sw=4 ts=4 fdm=marker * vim600: noet sw=4 ts=4 fdm=marker
* vim<600: noet sw=4 ts=4 * vim<600: noet sw=4 ts=4