diff options
| author | Remi Collet <fedora@famillecollet.com> | 2014-06-24 14:32:12 +0200 | 
|---|---|---|
| committer | Remi Collet <fedora@famillecollet.com> | 2014-06-24 14:32:12 +0200 | 
| commit | cd967adc8255376d9b3aa70f4a255c3f228c2a8b (patch) | |
| tree | 579148eb3e5d0effaf643e4f3b53a5d7c6dcd429 | |
| parent | f39479c31485313edd77e5f92b155280c3e08ff1 (diff) | |
php 5.6 more tests
| -rw-r--r-- | php-5.6.0-mock.patch | 32 | 
1 files changed, 31 insertions, 1 deletions
diff --git a/php-5.6.0-mock.patch b/php-5.6.0-mock.patch index 37bc452..4962971 100644 --- a/php-5.6.0-mock.patch +++ b/php-5.6.0-mock.patch @@ -14,7 +14,37 @@ diff -up php-5.6.0RC1/ext/standard/var_unserializer.c.mock php-5.6.0RC1/ext/stan   	(*p) += 2;  -	if (ce->serialize == NULL) { -+	if (ce->serialize == NULL || ce->unserialize == zend_user_unserialize || ZEND_INTERNAL_CLASS != ce->type) { ++	if (ce->serialize == NULL || ce->unserialize == zend_user_unserialize || (ZEND_INTERNAL_CLASS != ce->type && ce->create_object == NULL)) {   		object_init_ex(*rval, ce);   	} else {   		/* If this class implements Serializable, it should not land here but in object_custom(). The passed string +--- ext/reflection/php_reflection.c.orig	2014-06-24 13:23:11.265725787 +0200 ++++ ext/reflection/php_reflection.c	2014-06-24 13:49:40.659428346 +0200 +@@ -4295,11 +4295,16 @@ + { + 	reflection_object *intern; + 	zend_class_entry *ce; ++	zend_bool force = 0; +  + 	METHOD_NOTSTATIC(reflection_class_ptr); + 	GET_REFLECTION_OBJECT_PTR(ce); +  +-	if (ce->create_object != NULL) { ++	if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "|b", &force) == FAILURE) { ++		return; ++	} ++ ++	if (ce->create_object != NULL && !force) { + 		zend_throw_exception_ex(reflection_exception_ptr, 0 TSRMLS_CC, "Class %s is an internal class that cannot be instantiated without invoking its constructor", ce->name); + 	} +  +@@ -5874,7 +5879,8 @@ + 	ZEND_ARG_INFO(0, args) + ZEND_END_ARG_INFO() +  +-ZEND_BEGIN_ARG_INFO(arginfo_reflection_class_newInstanceWithoutConstructor, 0) ++ZEND_BEGIN_ARG_INFO_EX(arginfo_reflection_class_newInstanceWithoutConstructor, 0, 0, 0) ++	ZEND_ARG_INFO(0, force) + ZEND_END_ARG_INFO() +  + ZEND_BEGIN_ARG_INFO_EX(arginfo_reflection_class_newInstanceArgs, 0, 0, 0)  | 
