diff --git a/php/ChangeLog b/php/ChangeLog
index 3cee3b60..3eb64e72 100644
--- a/php/ChangeLog
+++ b/php/ChangeLog
@@ -1,5 +1,9 @@
msgpack extension changelog
+Version 0.3.1
+-------------
+ * Fix class MessagePackUnpacker.
+
Version 0.3.0
-------------
* Change msgpack_unpack.c (used template)
diff --git a/php/msgpack.c b/php/msgpack.c
index 5d4f9264..3b375ba4 100644
--- a/php/msgpack.c
+++ b/php/msgpack.c
@@ -113,7 +113,7 @@ zend_module_entry msgpack_module_entry = {
NULL,
ZEND_MINFO(msgpack),
#if ZEND_MODULE_API_NO >= 20010901
- MSGPACK_VERSION,
+ MSGPACK_EXTENSION_VERSION,
#endif
STANDARD_MODULE_PROPERTIES
};
diff --git a/php/msgpack_class.c b/php/msgpack_class.c
index 5cfff8d8..ce008d99 100644
--- a/php/msgpack_class.c
+++ b/php/msgpack_class.c
@@ -19,6 +19,7 @@ typedef struct {
msgpack_unpack_t mp;
php_unserialize_data_t var_hash;
long php_only;
+ zend_bool finished;
} php_msgpack_unpacker_t;
#if ZEND_MODULE_API_NO >= 20060613
@@ -348,6 +349,7 @@ static ZEND_METHOD(msgpack_unpacker, __construct)
unpacker->buffer.a = 0;
unpacker->retval = NULL;
unpacker->offset = 0;
+ unpacker->finished = 0;
template_init(&unpacker->mp);
@@ -460,6 +462,22 @@ static ZEND_METHOD(msgpack_unpacker, execute)
{
ALLOC_INIT_ZVAL(unpacker->retval);
}
+ else if (unpacker->finished)
+ {
+ zval_ptr_dtor(&unpacker->retval);
+
+ msgpack_unserialize_var_destroy(&unpacker->var_hash);
+
+
+ ALLOC_INIT_ZVAL(unpacker->retval);
+
+ template_init(&unpacker->mp);
+
+ msgpack_unserialize_var_init(&unpacker->var_hash);
+
+ (&unpacker->mp)->user.var_hash =
+ (php_unserialize_data_t *)&unpacker->var_hash;
+ }
(&unpacker->mp)->user.retval = (zval *)unpacker->retval;
MSGPACK_G(error_display) = 0;
@@ -483,6 +501,7 @@ static ZEND_METHOD(msgpack_unpacker, execute)
{
case MSGPACK_UNPACK_EXTRA_BYTES:
case MSGPACK_UNPACK_SUCCESS:
+ unpacker->finished = 1;
RETURN_TRUE;
default:
RETURN_FALSE;
@@ -493,7 +512,16 @@ static ZEND_METHOD(msgpack_unpacker, data)
{
MSGPACK_UNPACKER_OBJECT;
- RETURN_ZVAL(unpacker->retval, 1, 1);
+ if (unpacker->retval != NULL)
+ {
+ ZVAL_ZVAL(return_value, unpacker->retval, 1, 0);
+
+ MSGPACK_METHOD(msgpack_unpacker, reset, NULL, getThis());
+
+ return;
+ }
+
+ RETURN_FALSE;
}
static ZEND_METHOD(msgpack_unpacker, reset)
@@ -513,6 +541,7 @@ static ZEND_METHOD(msgpack_unpacker, reset)
unpacker->buffer.len = 0;
unpacker->buffer.a = 0;
unpacker->offset = 0;
+ unpacker->finished = 0;
if (buffer.len > 0)
{
@@ -530,12 +559,12 @@ static ZEND_METHOD(msgpack_unpacker, reset)
msgpack_unserialize_var_destroy(&unpacker->var_hash);
+ template_init(&unpacker->mp);
+
msgpack_unserialize_var_init(&unpacker->var_hash);
(&unpacker->mp)->user.var_hash =
(php_unserialize_data_t *)&unpacker->var_hash;
-
- msgpack_unserialize_init(&((&unpacker->mp)->user));
}
void msgpack_init_class()
diff --git a/php/package.xml b/php/package.xml
index 6172a4c5..803aa97d 100644
--- a/php/package.xml
+++ b/php/package.xml
@@ -10,11 +10,11 @@
advect@gmail.com
yes
- 2010-09-28
-
+ 2010-10-26
+
- 0.3.0
- 0.3.0
+ 0.3.1
+ 0.3.1
beta
@@ -27,14 +27,14 @@
-
-
+
+
-
+
@@ -49,8 +49,8 @@
-
-
+
+
@@ -65,14 +65,14 @@
-
-
+
+
-
-
+
+
-
-
+
+
@@ -82,22 +82,28 @@
-
+
-
-
-
-
+
+
+
+
-
-
-
-
-
-
-
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/php/php-msgpack.spec b/php/php-msgpack.spec
index 6a98288b..7609ca45 100644
--- a/php/php-msgpack.spec
+++ b/php/php-msgpack.spec
@@ -12,7 +12,6 @@ Packager: advect
Provides: php-pecl-msgpack
BuildRoot: %{_tmppath}/%{name}-%{version}-root
BuildRequires: php-devel
-Requires: msgpack
%if 0%{?php_zend_api}
Requires: php(zend-abi) = %{php_zend_api}
Requires: php(api) = %{php_core_api}
diff --git a/php/php_msgpack.h b/php/php_msgpack.h
index 61badea7..0791deb4 100644
--- a/php/php_msgpack.h
+++ b/php/php_msgpack.h
@@ -2,7 +2,7 @@
#ifndef PHP_MSGPACK_H
#define PHP_MSGPACK_H
-#define MSGPACK_EXTENSION_VERSION "0.3.0"
+#define MSGPACK_EXTENSION_VERSION "0.3.1"
#include "ext/standard/php_smart_str.h"
diff --git a/php/tests/009.phpt b/php/tests/009.phpt
index 9992988a..a1534c9a 100644
--- a/php/tests/009.phpt
+++ b/php/tests/009.phpt
@@ -2,8 +2,8 @@
Check for reference serialization
--SKIPIF--
= 0) {
- echo "skip tests in PHP 5.3.2 and lower";
+if (version_compare(PHP_VERSION, '5.3.2') <= 0) {
+ echo "skip tests in PHP 5.3.3 or newer";
}
--FILE--
&array(1) {
[0]=>
- &array(1) {
- [0]=>
- &array(1) {
- [0]=>
- *RECURSION*
- }
- }
+ *RECURSION*
}
}
}
@@ -91,13 +85,7 @@ array(1) {
[0]=>
&array(1) {
[0]=>
- &array(1) {
- [0]=>
- &array(1) {
- [0]=>
- *RECURSION*
- }
- }
+ *RECURSION*
}
}
}
@@ -107,13 +95,7 @@ array(1) {
[0]=>
&array(1) {
[0]=>
- &array(1) {
- [0]=>
- &array(1) {
- [0]=>
- *RECURSION*
- }
- }
+ *RECURSION*
}
}
}
diff --git a/php/tests/009b.phpt b/php/tests/009b.phpt
index 7765d62a..10e72593 100644
--- a/php/tests/009b.phpt
+++ b/php/tests/009b.phpt
@@ -2,8 +2,8 @@
Check for reference serialization
--SKIPIF--
= 0) {
+ echo "skip tests in PHP 5.3.2 or older";
}
--FILE--
&array(1) {
[0]=>
- *RECURSION*
+ &array(1) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ *RECURSION*
+ }
+ }
}
}
}
@@ -85,7 +91,13 @@ array(1) {
[0]=>
&array(1) {
[0]=>
- *RECURSION*
+ &array(1) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ *RECURSION*
+ }
+ }
}
}
}
@@ -95,7 +107,13 @@ array(1) {
[0]=>
&array(1) {
[0]=>
- *RECURSION*
+ &array(1) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ *RECURSION*
+ }
+ }
}
}
}
diff --git a/php/tests/024.phpt b/php/tests/024.phpt
index 9b185f7c..97db2a7d 100644
--- a/php/tests/024.phpt
+++ b/php/tests/024.phpt
@@ -2,8 +2,8 @@
Recursive objects
--SKIPIF--
= 0) {
- echo "skip tests in PHP 5.3.2 and lower";
+if (version_compare(PHP_VERSION, '5.3.2') <= 0) {
+ echo "skip tests in PHP 5.3.3 or newer";
}
--FILE--
int(100)
[%r"?obj"?:("Obj4":)?private"?%r]=>
- object(Obj4)#%d (2) {
- [%r"?a"?:("Obj4":)?private"?%r]=>
- int(100)
- [%r"?obj"?:("Obj4":)?private"?%r]=>
- *RECURSION*
- }
+ *RECURSION*
}
OK
diff --git a/php/tests/024b.phpt b/php/tests/024b.phpt
index 7c691bec..c7612d7f 100644
--- a/php/tests/024b.phpt
+++ b/php/tests/024b.phpt
@@ -2,8 +2,8 @@
Recursive objects
--SKIPIF--
= 0) {
+ echo "skip tests in PHP 5.3.2 or older";
}
--FILE--
int(100)
[%r"?obj"?:("Obj4":)?private"?%r]=>
- *RECURSION*
+ object(Obj4)#%d (2) {
+ [%r"?a"?:("Obj4":)?private"?%r]=>
+ int(100)
+ [%r"?obj"?:("Obj4":)?private"?%r]=>
+ *RECURSION*
+ }
}
OK
diff --git a/php/tests/026.phpt b/php/tests/026.phpt
index c243ef51..383289dd 100644
--- a/php/tests/026.phpt
+++ b/php/tests/026.phpt
@@ -3,8 +3,8 @@ Cyclic array test
--INI--
--SKIPIF--
= 0) {
- echo "skip tests in PHP 5.3.2 and lower";
+if (version_compare(PHP_VERSION, '5.3.2') <= 0) {
+ echo "skip tests in PHP 5.3.3 or newer";
}
--FILE--
- &array(2) {
- ["a"]=>
- array(2) {
- ["b"]=>
- string(1) "c"
- ["d"]=>
- string(1) "e"
- }
- ["f"]=>
- *RECURSION*
- }
+ *RECURSION*
}
}
OK
@@ -84,17 +74,7 @@ array(1) {
[1]=>
int(2)
[2]=>
- array(1) {
- ["foo"]=>
- &array(3) {
- [0]=>
- int(1)
- [1]=>
- int(2)
- [2]=>
- *RECURSION*
- }
- }
+ *RECURSION*
}
}
array(1) {
@@ -107,17 +87,7 @@ array(1) {
[2]=>
array(1) {
["foo"]=>
- &array(3) {
- [0]=>
- int(1)
- [1]=>
- int(2)
- [2]=>
- array(1) {
- ["foo"]=>
- *RECURSION*
- }
- }
+ *RECURSION*
}
}
}
@@ -131,17 +101,7 @@ array(1) {
[2]=>
array(1) {
["foo"]=>
- &array(3) {
- [0]=>
- int(1)
- [1]=>
- string(1) "b"
- [2]=>
- array(1) {
- ["foo"]=>
- *RECURSION*
- }
- }
+ *RECURSION*
}
}
}
diff --git a/php/tests/026b.phpt b/php/tests/026b.phpt
index f7a3381f..9eef7cb9 100644
--- a/php/tests/026b.phpt
+++ b/php/tests/026b.phpt
@@ -3,8 +3,8 @@ Cyclic array test
--INI--
--SKIPIF--
= 0) {
+ echo "skip tests in PHP 5.3.2 or older";
}
--FILE--
- *RECURSION*
+ &array(2) {
+ ["a"]=>
+ array(2) {
+ ["b"]=>
+ string(1) "c"
+ ["d"]=>
+ string(1) "e"
+ }
+ ["f"]=>
+ *RECURSION*
+ }
}
}
OK
@@ -74,7 +84,17 @@ array(1) {
[1]=>
int(2)
[2]=>
- *RECURSION*
+ array(1) {
+ ["foo"]=>
+ &array(3) {
+ [0]=>
+ int(1)
+ [1]=>
+ int(2)
+ [2]=>
+ *RECURSION*
+ }
+ }
}
}
array(1) {
@@ -87,7 +107,17 @@ array(1) {
[2]=>
array(1) {
["foo"]=>
- *RECURSION*
+ &array(3) {
+ [0]=>
+ int(1)
+ [1]=>
+ int(2)
+ [2]=>
+ array(1) {
+ ["foo"]=>
+ *RECURSION*
+ }
+ }
}
}
}
@@ -101,7 +131,17 @@ array(1) {
[2]=>
array(1) {
["foo"]=>
- *RECURSION*
+ &array(3) {
+ [0]=>
+ int(1)
+ [1]=>
+ string(1) "b"
+ [2]=>
+ array(1) {
+ ["foo"]=>
+ *RECURSION*
+ }
+ }
}
}
}
diff --git a/php/tests/028.phpt b/php/tests/028.phpt
index 00db6751..1d326ce1 100644
--- a/php/tests/028.phpt
+++ b/php/tests/028.phpt
@@ -2,8 +2,8 @@
Serialize object into session, full set
--SKIPIF--
= 0) {
- echo "skip tests in PHP 5.3.2 and lower";
+if (version_compare(PHP_VERSION, '5.3.2') <= 0) {
+ echo "skip tests in PHP 5.3.3 or newer";
}
--FILE--
object(Bar)#4 (3) {
["d1"]=>
- object(Foo)#3 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- [%r"?d2"?:protected"?%r]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- ["d3"]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- }
+ *RECURSION*
[%r"?d2"?:("Bar":)?private"?%r]=>
- object(Foo)#3 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- [%r"?d2"?:protected"?%r]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- ["d3"]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- }
+ *RECURSION*
[%r"?d3"?:protected"?%r]=>
- object(Foo)#3 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- [%r"?d2"?:protected"?%r]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- ["d3"]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- }
+ *RECURSION*
}
[%r"?d2"?:protected"?%r]=>
object(Bar)#4 (3) {
["d1"]=>
- object(Foo)#3 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- [%r"?d2"?:protected"?%r]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- ["d3"]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- }
+ *RECURSION*
[%r"?d2"?:("Bar":)?private"?%r]=>
- object(Foo)#3 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- [%r"?d2"?:protected"?%r]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- ["d3"]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- }
+ *RECURSION*
[%r"?d3"?:protected"?%r]=>
- object(Foo)#3 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- [%r"?d2"?:protected"?%r]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- ["d3"]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- }
+ *RECURSION*
}
["d3"]=>
object(Bar)#4 (3) {
["d1"]=>
- object(Foo)#3 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- [%r"?d2"?:protected"?%r]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- ["d3"]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- }
+ *RECURSION*
[%r"?d2"?:("Bar":)?private"?%r]=>
- object(Foo)#3 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- [%r"?d2"?:protected"?%r]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- ["d3"]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- }
+ *RECURSION*
[%r"?d3"?:protected"?%r]=>
- object(Foo)#3 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- [%r"?d2"?:protected"?%r]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- ["d3"]=>
- object(Bar)#4 (3) {
- ["d1"]=>
- *RECURSION*
- [%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
- [%r"?d3"?:protected"?%r]=>
- *RECURSION*
- }
- }
+ *RECURSION*
}
}
["test"]=>
@@ -391,281 +139,29 @@ array(3) {
["d1"]=>
object(Foo)#6 (3) {
[%r"?d1"?:("Foo":)?private"?%r]=>
- object(Bar)#5 (3) {
- ["d1"]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- [%r"?d2"?:("Bar":)?private"?%r]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- [%r"?d3"?:protected"?%r]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- }
+ *RECURSION*
[%r"?d2"?:protected"?%r]=>
- object(Bar)#5 (3) {
- ["d1"]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- [%r"?d2"?:("Bar":)?private"?%r]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- [%r"?d3"?:protected"?%r]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- }
+ *RECURSION*
["d3"]=>
- object(Bar)#5 (3) {
- ["d1"]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- [%r"?d2"?:("Bar":)?private"?%r]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- [%r"?d3"?:protected"?%r]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- }
+ *RECURSION*
}
[%r"?d2"?:("Bar":)?private"?%r]=>
object(Foo)#6 (3) {
[%r"?d1"?:("Foo":)?private"?%r]=>
- object(Bar)#5 (3) {
- ["d1"]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- [%r"?d2"?:("Bar":)?private"?%r]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- [%r"?d3"?:protected"?%r]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- }
+ *RECURSION*
[%r"?d2"?:protected"?%r]=>
- object(Bar)#5 (3) {
- ["d1"]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- [%r"?d2"?:("Bar":)?private"?%r]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- [%r"?d3"?:protected"?%r]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- }
+ *RECURSION*
["d3"]=>
- object(Bar)#5 (3) {
- ["d1"]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- [%r"?d2"?:("Bar":)?private"?%r]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- [%r"?d3"?:protected"?%r]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- }
+ *RECURSION*
}
[%r"?d3"?:protected"?%r]=>
object(Foo)#6 (3) {
[%r"?d1"?:("Foo":)?private"?%r]=>
- object(Bar)#5 (3) {
- ["d1"]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- [%r"?d2"?:("Bar":)?private"?%r]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- [%r"?d3"?:protected"?%r]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- }
+ *RECURSION*
[%r"?d2"?:protected"?%r]=>
- object(Bar)#5 (3) {
- ["d1"]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- [%r"?d2"?:("Bar":)?private"?%r]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- [%r"?d3"?:protected"?%r]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- }
+ *RECURSION*
["d3"]=>
- object(Bar)#5 (3) {
- ["d1"]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- [%r"?d2"?:("Bar":)?private"?%r]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- [%r"?d3"?:protected"?%r]=>
- object(Foo)#6 (3) {
- [%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
- [%r"?d2"?:protected"?%r]=>
- *RECURSION*
- ["d3"]=>
- *RECURSION*
- }
- }
+ *RECURSION*
}
}
}
diff --git a/php/tests/028b.phpt b/php/tests/028b.phpt
index 7331a576..0efba186 100644
--- a/php/tests/028b.phpt
+++ b/php/tests/028b.phpt
@@ -2,8 +2,8 @@
Serialize object into session, full set
--SKIPIF--
= 0) {
+ echo "skip tests in PHP 5.3.2 or older";
}
--FILE--
object(Bar)#4 (3) {
["d1"]=>
- *RECURSION*
+ object(Foo)#3 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ [%r"?d2"?:protected"?%r]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ ["d3"]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ }
[%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
+ object(Foo)#3 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ [%r"?d2"?:protected"?%r]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ ["d3"]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ }
[%r"?d3"?:protected"?%r]=>
- *RECURSION*
+ object(Foo)#3 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ [%r"?d2"?:protected"?%r]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ ["d3"]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ }
}
[%r"?d2"?:protected"?%r]=>
object(Bar)#4 (3) {
["d1"]=>
- *RECURSION*
+ object(Foo)#3 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ [%r"?d2"?:protected"?%r]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ ["d3"]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ }
[%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
+ object(Foo)#3 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ [%r"?d2"?:protected"?%r]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ ["d3"]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ }
[%r"?d3"?:protected"?%r]=>
- *RECURSION*
+ object(Foo)#3 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ [%r"?d2"?:protected"?%r]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ ["d3"]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ }
}
["d3"]=>
object(Bar)#4 (3) {
["d1"]=>
- *RECURSION*
+ object(Foo)#3 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ [%r"?d2"?:protected"?%r]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ ["d3"]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ }
[%r"?d2"?:("Bar":)?private"?%r]=>
- *RECURSION*
+ object(Foo)#3 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ [%r"?d2"?:protected"?%r]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ ["d3"]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ }
[%r"?d3"?:protected"?%r]=>
- *RECURSION*
+ object(Foo)#3 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ [%r"?d2"?:protected"?%r]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ ["d3"]=>
+ object(Bar)#4 (3) {
+ ["d1"]=>
+ *RECURSION*
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d3"?:protected"?%r]=>
+ *RECURSION*
+ }
+ }
}
}
["test"]=>
@@ -139,29 +391,281 @@ array(3) {
["d1"]=>
object(Foo)#6 (3) {
[%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
+ object(Bar)#5 (3) {
+ ["d1"]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ [%r"?d3"?:protected"?%r]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ }
[%r"?d2"?:protected"?%r]=>
- *RECURSION*
+ object(Bar)#5 (3) {
+ ["d1"]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ [%r"?d3"?:protected"?%r]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ }
["d3"]=>
- *RECURSION*
+ object(Bar)#5 (3) {
+ ["d1"]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ [%r"?d3"?:protected"?%r]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ }
}
[%r"?d2"?:("Bar":)?private"?%r]=>
object(Foo)#6 (3) {
[%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
+ object(Bar)#5 (3) {
+ ["d1"]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ [%r"?d3"?:protected"?%r]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ }
[%r"?d2"?:protected"?%r]=>
- *RECURSION*
+ object(Bar)#5 (3) {
+ ["d1"]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ [%r"?d3"?:protected"?%r]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ }
["d3"]=>
- *RECURSION*
+ object(Bar)#5 (3) {
+ ["d1"]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ [%r"?d3"?:protected"?%r]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ }
}
[%r"?d3"?:protected"?%r]=>
object(Foo)#6 (3) {
[%r"?d1"?:("Foo":)?private"?%r]=>
- *RECURSION*
+ object(Bar)#5 (3) {
+ ["d1"]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ [%r"?d3"?:protected"?%r]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ }
[%r"?d2"?:protected"?%r]=>
- *RECURSION*
+ object(Bar)#5 (3) {
+ ["d1"]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ [%r"?d3"?:protected"?%r]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ }
["d3"]=>
- *RECURSION*
+ object(Bar)#5 (3) {
+ ["d1"]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ [%r"?d2"?:("Bar":)?private"?%r]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ [%r"?d3"?:protected"?%r]=>
+ object(Foo)#6 (3) {
+ [%r"?d1"?:("Foo":)?private"?%r]=>
+ *RECURSION*
+ [%r"?d2"?:protected"?%r]=>
+ *RECURSION*
+ ["d3"]=>
+ *RECURSION*
+ }
+ }
}
}
}
diff --git a/php/tests/042.phpt b/php/tests/042.phpt
index 2ba73ac9..83e8bc71 100644
--- a/php/tests/042.phpt
+++ b/php/tests/042.phpt
@@ -3,7 +3,7 @@ Closure
--SKIPIF--
= 0) {
- echo "skip tests in PHP 5.3.2 and lower";
+if (version_compare(PHP_VERSION, '5.3.2') <= 0) {
+ echo "skip tests in PHP 5.3.3 or newer";
}
--FILE--
&array(1) {
[0]=>
- &array(1) {
- [0]=>
- &array(1) {
- [0]=>
- *RECURSION*
- }
- }
+ *RECURSION*
}
}
}
diff --git a/php/tests/060b.phpt b/php/tests/060b.phpt
index 0b947c8e..a2e50bcc 100644
--- a/php/tests/060b.phpt
+++ b/php/tests/060b.phpt
@@ -2,8 +2,8 @@
Check for buffered streaming unserialization
--SKIPIF--
= 0) {
+ echo "skip tests in PHP 5.3.2 or older";
}
--FILE--
&array(1) {
[0]=>
- *RECURSION*
+ &array(1) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ *RECURSION*
+ }
+ }
}
}
}
diff --git a/php/tests/061.phpt b/php/tests/061.phpt
index 7ecc0c9f..2b42d310 100644
--- a/php/tests/061.phpt
+++ b/php/tests/061.phpt
@@ -2,8 +2,8 @@
Check for unbuffered streaming unserialization
--SKIPIF--
= 0) {
- echo "skip tests in PHP 5.3.2 and lower";
+if (version_compare(PHP_VERSION, '5.3.2') <= 0) {
+ echo "skip tests in PHP 5.3.3 or newer";
}
--FILE--
&array(1) {
[0]=>
- &array(1) {
- [0]=>
- &array(1) {
- [0]=>
- *RECURSION*
- }
- }
+ *RECURSION*
}
}
}
diff --git a/php/tests/061b.phpt b/php/tests/061b.phpt
index efb3a9bf..21706db7 100644
--- a/php/tests/061b.phpt
+++ b/php/tests/061b.phpt
@@ -2,8 +2,8 @@
Check for unbuffered streaming unserialization
--SKIPIF--
= 0) {
+ echo "skip tests in PHP 5.3.2 or older";
}
--FILE--
&array(1) {
[0]=>
- *RECURSION*
+ &array(1) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ *RECURSION*
+ }
+ }
}
}
}
diff --git a/php/tests/064.phpt b/php/tests/064.phpt
new file mode 100644
index 00000000..a7a2f3bc
--- /dev/null
+++ b/php/tests/064.phpt
@@ -0,0 +1,315 @@
+--TEST--
+Check for buffered streaming unserialization (single)
+--SKIPIF--
+feed($str);
+ if ($unpacker->execute())
+ {
+ $unserialized = $unpacker->data();
+ var_dump($unserialized);
+ $unpacker->reset();
+ }
+
+ $i += $len;
+ }
+
+ if (!is_bool($test))
+ {
+ echo $unserialized === $variable ? 'OK' : 'ERROR', PHP_EOL;
+ }
+ else
+ {
+ echo $test || $unserialized == $variable ? 'OK' : 'ERROR', PHP_EOL;
+ }
+}
+
+test('null', null);
+
+test('bool: true', true);
+test('bool: false', false);
+
+test('zero: 0', 0);
+test('small: 1', 1);
+test('small: -1', -1);
+test('medium: 1000', 1000);
+test('medium: -1000', -1000);
+test('large: 100000', 100000);
+test('large: -100000', -100000);
+
+test('double: 123.456', 123.456);
+
+test('empty: ""', "");
+test('string: "foobar"', "foobar");
+
+test('array', array(), false);
+test('array(1, 2, 3)', array(1, 2, 3), false);
+test('array(array(1, 2, 3), arr...', array(array(1, 2, 3), array(4, 5, 6), array(7, 8, 9)), false);
+
+test('array("foo", "foo", "foo")', array("foo", "foo", "foo"), false);
+test('array("one" => 1, "two" => 2))', array("one" => 1, "two" => 2), false);
+test('array("kek" => "lol", "lol" => "kek")', array("kek" => "lol", "lol" => "kek"), false);
+test('array("" => "empty")', array("" => "empty"), false);
+
+$a = array('foo');
+test('array($a, $a)', array($a, $a), false);
+test('array(&$a, &$a)', array(&$a, &$a), false);
+
+$a = array(null);
+$b = array(&$a);
+$a[0] = &$b;
+
+test('cyclic', $a, true);
+
+$a = array(
+ 'a' => array(
+ 'b' => 'c',
+ 'd' => 'e'
+ ),
+ 'f' => array(
+ 'g' => 'h'
+ )
+ );
+
+test('array', $a, false);
+
+class Obj {
+ public $a;
+ protected $b;
+ private $c;
+
+ function __construct($a, $b, $c) {
+ $this->a = $a;
+ $this->b = $b;
+ $this->c = $c;
+ }
+}
+
+test('object', new Obj(1, 2, 3), false);
+
+test('object', array(new Obj(1, 2, 3), new Obj(4, 5, 6)), false);
+
+$o = new Obj(1, 2, 3);
+
+test('object', array(&$o, &$o), false);
+--EXPECTF--
+NULL
+OK
+bool(true)
+OK
+bool(false)
+OK
+int(0)
+OK
+int(1)
+OK
+int(-1)
+OK
+int(1000)
+OK
+int(-1000)
+OK
+int(100000)
+OK
+int(-100000)
+OK
+float(123.456)
+OK
+string(0) ""
+OK
+string(6) "foobar"
+OK
+array(0) {
+}
+OK
+array(3) {
+ [0]=>
+ int(1)
+ [1]=>
+ int(2)
+ [2]=>
+ int(3)
+}
+OK
+array(3) {
+ [0]=>
+ array(3) {
+ [0]=>
+ int(1)
+ [1]=>
+ int(2)
+ [2]=>
+ int(3)
+ }
+ [1]=>
+ array(3) {
+ [0]=>
+ int(4)
+ [1]=>
+ int(5)
+ [2]=>
+ int(6)
+ }
+ [2]=>
+ array(3) {
+ [0]=>
+ int(7)
+ [1]=>
+ int(8)
+ [2]=>
+ int(9)
+ }
+}
+OK
+array(3) {
+ [0]=>
+ string(3) "foo"
+ [1]=>
+ string(3) "foo"
+ [2]=>
+ string(3) "foo"
+}
+OK
+array(2) {
+ ["one"]=>
+ int(1)
+ ["two"]=>
+ int(2)
+}
+OK
+array(2) {
+ ["kek"]=>
+ string(3) "lol"
+ ["lol"]=>
+ string(3) "kek"
+}
+OK
+array(1) {
+ [""]=>
+ string(5) "empty"
+}
+OK
+array(2) {
+ [0]=>
+ array(1) {
+ [0]=>
+ string(3) "foo"
+ }
+ [1]=>
+ array(1) {
+ [0]=>
+ string(3) "foo"
+ }
+}
+OK
+array(2) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ string(3) "foo"
+ }
+ [1]=>
+ &array(1) {
+ [0]=>
+ string(3) "foo"
+ }
+}
+OK
+array(1) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ *RECURSION*
+ }
+ }
+}
+OK
+array(2) {
+ ["a"]=>
+ array(2) {
+ ["b"]=>
+ string(1) "c"
+ ["d"]=>
+ string(1) "e"
+ }
+ ["f"]=>
+ array(1) {
+ ["g"]=>
+ string(1) "h"
+ }
+}
+OK
+object(Obj)#%d (3) {
+ ["a"]=>
+ int(1)
+ [%r"?b"?:protected"?%r]=>
+ int(2)
+ [%r"?c"?:("Obj":)?private"?%r]=>
+ int(3)
+}
+OK
+array(2) {
+ [0]=>
+ object(Obj)#%d (3) {
+ ["a"]=>
+ int(1)
+ [%r"?b"?:protected"?%r]=>
+ int(2)
+ [%r"?c"?:("Obj":)?private"?%r]=>
+ int(3)
+ }
+ [1]=>
+ object(Obj)#%d (3) {
+ ["a"]=>
+ int(4)
+ [%r"?b"?:protected"?%r]=>
+ int(5)
+ [%r"?c"?:("Obj":)?private"?%r]=>
+ int(6)
+ }
+}
+OK
+array(2) {
+ [0]=>
+ &object(Obj)#%d (3) {
+ ["a"]=>
+ int(1)
+ [%r"?b"?:protected"?%r]=>
+ int(2)
+ [%r"?c"?:("Obj":)?private"?%r]=>
+ int(3)
+ }
+ [1]=>
+ &object(Obj)#%d (3) {
+ ["a"]=>
+ int(1)
+ [%r"?b"?:protected"?%r]=>
+ int(2)
+ [%r"?c"?:("Obj":)?private"?%r]=>
+ int(3)
+ }
+}
+OK
diff --git a/php/tests/064b.phpt b/php/tests/064b.phpt
new file mode 100644
index 00000000..aba7a2d7
--- /dev/null
+++ b/php/tests/064b.phpt
@@ -0,0 +1,321 @@
+--TEST--
+Check for buffered streaming unserialization (single)
+--SKIPIF--
+= 0) {
+ echo "skip tests in PHP 5.3.2 or older";
+}
+--FILE--
+feed($str);
+ if ($unpacker->execute())
+ {
+ $unserialized = $unpacker->data();
+ var_dump($unserialized);
+ $unpacker->reset();
+ }
+
+ $i += $len;
+ }
+
+ if (!is_bool($test))
+ {
+ echo $unserialized === $variable ? 'OK' : 'ERROR', PHP_EOL;
+ }
+ else
+ {
+ echo $test || $unserialized == $variable ? 'OK' : 'ERROR', PHP_EOL;
+ }
+}
+
+test('null', null);
+
+test('bool: true', true);
+test('bool: false', false);
+
+test('zero: 0', 0);
+test('small: 1', 1);
+test('small: -1', -1);
+test('medium: 1000', 1000);
+test('medium: -1000', -1000);
+test('large: 100000', 100000);
+test('large: -100000', -100000);
+
+test('double: 123.456', 123.456);
+
+test('empty: ""', "");
+test('string: "foobar"', "foobar");
+
+test('array', array(), false);
+test('array(1, 2, 3)', array(1, 2, 3), false);
+test('array(array(1, 2, 3), arr...', array(array(1, 2, 3), array(4, 5, 6), array(7, 8, 9)), false);
+
+test('array("foo", "foo", "foo")', array("foo", "foo", "foo"), false);
+test('array("one" => 1, "two" => 2))', array("one" => 1, "two" => 2), false);
+test('array("kek" => "lol", "lol" => "kek")', array("kek" => "lol", "lol" => "kek"), false);
+test('array("" => "empty")', array("" => "empty"), false);
+
+$a = array('foo');
+test('array($a, $a)', array($a, $a), false);
+test('array(&$a, &$a)', array(&$a, &$a), false);
+
+$a = array(null);
+$b = array(&$a);
+$a[0] = &$b;
+
+test('cyclic', $a, true);
+
+$a = array(
+ 'a' => array(
+ 'b' => 'c',
+ 'd' => 'e'
+ ),
+ 'f' => array(
+ 'g' => 'h'
+ )
+ );
+
+test('array', $a, false);
+
+class Obj {
+ public $a;
+ protected $b;
+ private $c;
+
+ function __construct($a, $b, $c) {
+ $this->a = $a;
+ $this->b = $b;
+ $this->c = $c;
+ }
+}
+
+test('object', new Obj(1, 2, 3), false);
+
+test('object', array(new Obj(1, 2, 3), new Obj(4, 5, 6)), false);
+
+$o = new Obj(1, 2, 3);
+
+test('object', array(&$o, &$o), false);
+--EXPECTF--
+NULL
+OK
+bool(true)
+OK
+bool(false)
+OK
+int(0)
+OK
+int(1)
+OK
+int(-1)
+OK
+int(1000)
+OK
+int(-1000)
+OK
+int(100000)
+OK
+int(-100000)
+OK
+float(123.456)
+OK
+string(0) ""
+OK
+string(6) "foobar"
+OK
+array(0) {
+}
+OK
+array(3) {
+ [0]=>
+ int(1)
+ [1]=>
+ int(2)
+ [2]=>
+ int(3)
+}
+OK
+array(3) {
+ [0]=>
+ array(3) {
+ [0]=>
+ int(1)
+ [1]=>
+ int(2)
+ [2]=>
+ int(3)
+ }
+ [1]=>
+ array(3) {
+ [0]=>
+ int(4)
+ [1]=>
+ int(5)
+ [2]=>
+ int(6)
+ }
+ [2]=>
+ array(3) {
+ [0]=>
+ int(7)
+ [1]=>
+ int(8)
+ [2]=>
+ int(9)
+ }
+}
+OK
+array(3) {
+ [0]=>
+ string(3) "foo"
+ [1]=>
+ string(3) "foo"
+ [2]=>
+ string(3) "foo"
+}
+OK
+array(2) {
+ ["one"]=>
+ int(1)
+ ["two"]=>
+ int(2)
+}
+OK
+array(2) {
+ ["kek"]=>
+ string(3) "lol"
+ ["lol"]=>
+ string(3) "kek"
+}
+OK
+array(1) {
+ [""]=>
+ string(5) "empty"
+}
+OK
+array(2) {
+ [0]=>
+ array(1) {
+ [0]=>
+ string(3) "foo"
+ }
+ [1]=>
+ array(1) {
+ [0]=>
+ string(3) "foo"
+ }
+}
+OK
+array(2) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ string(3) "foo"
+ }
+ [1]=>
+ &array(1) {
+ [0]=>
+ string(3) "foo"
+ }
+}
+OK
+array(1) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ *RECURSION*
+ }
+ }
+ }
+ }
+}
+OK
+array(2) {
+ ["a"]=>
+ array(2) {
+ ["b"]=>
+ string(1) "c"
+ ["d"]=>
+ string(1) "e"
+ }
+ ["f"]=>
+ array(1) {
+ ["g"]=>
+ string(1) "h"
+ }
+}
+OK
+object(Obj)#%d (3) {
+ ["a"]=>
+ int(1)
+ [%r"?b"?:protected"?%r]=>
+ int(2)
+ [%r"?c"?:("Obj":)?private"?%r]=>
+ int(3)
+}
+OK
+array(2) {
+ [0]=>
+ object(Obj)#%d (3) {
+ ["a"]=>
+ int(1)
+ [%r"?b"?:protected"?%r]=>
+ int(2)
+ [%r"?c"?:("Obj":)?private"?%r]=>
+ int(3)
+ }
+ [1]=>
+ object(Obj)#%d (3) {
+ ["a"]=>
+ int(4)
+ [%r"?b"?:protected"?%r]=>
+ int(5)
+ [%r"?c"?:("Obj":)?private"?%r]=>
+ int(6)
+ }
+}
+OK
+array(2) {
+ [0]=>
+ &object(Obj)#%d (3) {
+ ["a"]=>
+ int(1)
+ [%r"?b"?:protected"?%r]=>
+ int(2)
+ [%r"?c"?:("Obj":)?private"?%r]=>
+ int(3)
+ }
+ [1]=>
+ &object(Obj)#%d (3) {
+ ["a"]=>
+ int(1)
+ [%r"?b"?:protected"?%r]=>
+ int(2)
+ [%r"?c"?:("Obj":)?private"?%r]=>
+ int(3)
+ }
+}
+OK
diff --git a/php/tests/065.phpt b/php/tests/065.phpt
new file mode 100644
index 00000000..c37ca129
--- /dev/null
+++ b/php/tests/065.phpt
@@ -0,0 +1,320 @@
+--TEST--
+Check for unbuffered streaming unserialization (single)
+--SKIPIF--
+execute($str, $offset))
+ {
+ $unserialized = $unpacker->data();
+ var_dump($unserialized);
+
+ $unpacker->reset();
+ $str = "";
+ $offset = 0;
+ }
+
+ $i += $len;
+ }
+
+ if (!is_bool($test))
+ {
+ echo $unserialized === $variable ? 'OK' : 'ERROR', PHP_EOL;
+ }
+ else
+ {
+ echo $test || $unserialized == $variable ? 'OK' : 'ERROR', PHP_EOL;
+ }
+}
+
+test('null', null);
+
+test('boo:l true', true);
+test('bool: true', false);
+
+test('zero: 0', 0);
+test('small: 1', 1);
+test('small: -1', -1);
+test('medium: 1000', 1000);
+test('medium: -1000', -1000);
+test('large: 100000', 100000);
+test('large: -100000', -100000);
+
+test('double: 123.456', 123.456);
+
+test('empty: ""', "");
+test('string: "foobar"', "foobar");
+
+test('empty: array', array(), false);
+test('empty: array(1, 2, 3)', array(1, 2, 3), false);
+test('empty: array(array(1, 2, 3), arr...', array(array(1, 2, 3), array(4, 5, 6), array(7, 8, 9)), false);
+
+test('array("foo", "foo", "foo")', array("foo", "foo", "foo"), false);
+test('array("one" => 1, "two" => 2))', array("one" => 1, "two" => 2), false);
+test('array("kek" => "lol", "lol" => "kek")', array("kek" => "lol", "lol" => "kek"), false);
+test('array("" => "empty")', array("" => "empty"), false);
+
+$a = array('foo');
+test('array($a, $a)', array($a, $a), false);
+test('array(&$a, &$a)', array(&$a, &$a), false);
+
+$a = array(null);
+$b = array(&$a);
+$a[0] = &$b;
+
+test('cyclic', $a, true);
+
+$a = array(
+ 'a' => array(
+ 'b' => 'c',
+ 'd' => 'e'
+ ),
+ 'f' => array(
+ 'g' => 'h'
+ )
+ );
+
+test('array', $a, false);
+
+class Obj {
+ public $a;
+ protected $b;
+ private $c;
+
+ function __construct($a, $b, $c) {
+ $this->a = $a;
+ $this->b = $b;
+ $this->c = $c;
+ }
+}
+
+test('object', new Obj(1, 2, 3), false);
+
+test('object', array(new Obj(1, 2, 3), new Obj(4, 5, 6)), false);
+
+$o = new Obj(1, 2, 3);
+
+test('object', array(&$o, &$o), false);
+--EXPECTF--
+NULL
+OK
+bool(true)
+OK
+bool(false)
+OK
+int(0)
+OK
+int(1)
+OK
+int(-1)
+OK
+int(1000)
+OK
+int(-1000)
+OK
+int(100000)
+OK
+int(-100000)
+OK
+float(123.456)
+OK
+string(0) ""
+OK
+string(6) "foobar"
+OK
+array(0) {
+}
+OK
+array(3) {
+ [0]=>
+ int(1)
+ [1]=>
+ int(2)
+ [2]=>
+ int(3)
+}
+OK
+array(3) {
+ [0]=>
+ array(3) {
+ [0]=>
+ int(1)
+ [1]=>
+ int(2)
+ [2]=>
+ int(3)
+ }
+ [1]=>
+ array(3) {
+ [0]=>
+ int(4)
+ [1]=>
+ int(5)
+ [2]=>
+ int(6)
+ }
+ [2]=>
+ array(3) {
+ [0]=>
+ int(7)
+ [1]=>
+ int(8)
+ [2]=>
+ int(9)
+ }
+}
+OK
+array(3) {
+ [0]=>
+ string(3) "foo"
+ [1]=>
+ string(3) "foo"
+ [2]=>
+ string(3) "foo"
+}
+OK
+array(2) {
+ ["one"]=>
+ int(1)
+ ["two"]=>
+ int(2)
+}
+OK
+array(2) {
+ ["kek"]=>
+ string(3) "lol"
+ ["lol"]=>
+ string(3) "kek"
+}
+OK
+array(1) {
+ [""]=>
+ string(5) "empty"
+}
+OK
+array(2) {
+ [0]=>
+ array(1) {
+ [0]=>
+ string(3) "foo"
+ }
+ [1]=>
+ array(1) {
+ [0]=>
+ string(3) "foo"
+ }
+}
+OK
+array(2) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ string(3) "foo"
+ }
+ [1]=>
+ &array(1) {
+ [0]=>
+ string(3) "foo"
+ }
+}
+OK
+array(1) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ *RECURSION*
+ }
+ }
+}
+OK
+array(2) {
+ ["a"]=>
+ array(2) {
+ ["b"]=>
+ string(1) "c"
+ ["d"]=>
+ string(1) "e"
+ }
+ ["f"]=>
+ array(1) {
+ ["g"]=>
+ string(1) "h"
+ }
+}
+OK
+object(Obj)#%d (3) {
+ ["a"]=>
+ int(1)
+ [%r"?b"?:protected"?%r]=>
+ int(2)
+ [%r"?c"?:("Obj":)?private"?%r]=>
+ int(3)
+}
+OK
+array(2) {
+ [0]=>
+ object(Obj)#%d (3) {
+ ["a"]=>
+ int(1)
+ [%r"?b"?:protected"?%r]=>
+ int(2)
+ [%r"?c"?:("Obj":)?private"?%r]=>
+ int(3)
+ }
+ [1]=>
+ object(Obj)#%d (3) {
+ ["a"]=>
+ int(4)
+ [%r"?b"?:protected"?%r]=>
+ int(5)
+ [%r"?c"?:("Obj":)?private"?%r]=>
+ int(6)
+ }
+}
+OK
+array(2) {
+ [0]=>
+ &object(Obj)#%d (3) {
+ ["a"]=>
+ int(1)
+ [%r"?b"?:protected"?%r]=>
+ int(2)
+ [%r"?c"?:("Obj":)?private"?%r]=>
+ int(3)
+ }
+ [1]=>
+ &object(Obj)#%d (3) {
+ ["a"]=>
+ int(1)
+ [%r"?b"?:protected"?%r]=>
+ int(2)
+ [%r"?c"?:("Obj":)?private"?%r]=>
+ int(3)
+ }
+}
+OK
diff --git a/php/tests/065b.phpt b/php/tests/065b.phpt
new file mode 100644
index 00000000..c623d9a0
--- /dev/null
+++ b/php/tests/065b.phpt
@@ -0,0 +1,326 @@
+--TEST--
+Check for unbuffered streaming unserialization (single)
+--SKIPIF--
+= 0) {
+ echo "skip tests in PHP 5.3.2 or older";
+}
+--FILE--
+execute($str, $offset))
+ {
+ $unserialized = $unpacker->data();
+ var_dump($unserialized);
+
+ $unpacker->reset();
+ $str = "";
+ $offset = 0;
+ }
+
+ $i += $len;
+ }
+
+ if (!is_bool($test))
+ {
+ echo $unserialized === $variable ? 'OK' : 'ERROR', PHP_EOL;
+ }
+ else
+ {
+ echo $test || $unserialized == $variable ? 'OK' : 'ERROR', PHP_EOL;
+ }
+}
+
+test('null', null);
+
+test('boo:l true', true);
+test('bool: true', false);
+
+test('zero: 0', 0);
+test('small: 1', 1);
+test('small: -1', -1);
+test('medium: 1000', 1000);
+test('medium: -1000', -1000);
+test('large: 100000', 100000);
+test('large: -100000', -100000);
+
+test('double: 123.456', 123.456);
+
+test('empty: ""', "");
+test('string: "foobar"', "foobar");
+
+test('empty: array', array(), false);
+test('empty: array(1, 2, 3)', array(1, 2, 3), false);
+test('empty: array(array(1, 2, 3), arr...', array(array(1, 2, 3), array(4, 5, 6), array(7, 8, 9)), false);
+
+test('array("foo", "foo", "foo")', array("foo", "foo", "foo"), false);
+test('array("one" => 1, "two" => 2))', array("one" => 1, "two" => 2), false);
+test('array("kek" => "lol", "lol" => "kek")', array("kek" => "lol", "lol" => "kek"), false);
+test('array("" => "empty")', array("" => "empty"), false);
+
+$a = array('foo');
+test('array($a, $a)', array($a, $a), false);
+test('array(&$a, &$a)', array(&$a, &$a), false);
+
+$a = array(null);
+$b = array(&$a);
+$a[0] = &$b;
+
+test('cyclic', $a, true);
+
+$a = array(
+ 'a' => array(
+ 'b' => 'c',
+ 'd' => 'e'
+ ),
+ 'f' => array(
+ 'g' => 'h'
+ )
+ );
+
+test('array', $a, false);
+
+class Obj {
+ public $a;
+ protected $b;
+ private $c;
+
+ function __construct($a, $b, $c) {
+ $this->a = $a;
+ $this->b = $b;
+ $this->c = $c;
+ }
+}
+
+test('object', new Obj(1, 2, 3), false);
+
+test('object', array(new Obj(1, 2, 3), new Obj(4, 5, 6)), false);
+
+$o = new Obj(1, 2, 3);
+
+test('object', array(&$o, &$o), false);
+--EXPECTF--
+NULL
+OK
+bool(true)
+OK
+bool(false)
+OK
+int(0)
+OK
+int(1)
+OK
+int(-1)
+OK
+int(1000)
+OK
+int(-1000)
+OK
+int(100000)
+OK
+int(-100000)
+OK
+float(123.456)
+OK
+string(0) ""
+OK
+string(6) "foobar"
+OK
+array(0) {
+}
+OK
+array(3) {
+ [0]=>
+ int(1)
+ [1]=>
+ int(2)
+ [2]=>
+ int(3)
+}
+OK
+array(3) {
+ [0]=>
+ array(3) {
+ [0]=>
+ int(1)
+ [1]=>
+ int(2)
+ [2]=>
+ int(3)
+ }
+ [1]=>
+ array(3) {
+ [0]=>
+ int(4)
+ [1]=>
+ int(5)
+ [2]=>
+ int(6)
+ }
+ [2]=>
+ array(3) {
+ [0]=>
+ int(7)
+ [1]=>
+ int(8)
+ [2]=>
+ int(9)
+ }
+}
+OK
+array(3) {
+ [0]=>
+ string(3) "foo"
+ [1]=>
+ string(3) "foo"
+ [2]=>
+ string(3) "foo"
+}
+OK
+array(2) {
+ ["one"]=>
+ int(1)
+ ["two"]=>
+ int(2)
+}
+OK
+array(2) {
+ ["kek"]=>
+ string(3) "lol"
+ ["lol"]=>
+ string(3) "kek"
+}
+OK
+array(1) {
+ [""]=>
+ string(5) "empty"
+}
+OK
+array(2) {
+ [0]=>
+ array(1) {
+ [0]=>
+ string(3) "foo"
+ }
+ [1]=>
+ array(1) {
+ [0]=>
+ string(3) "foo"
+ }
+}
+OK
+array(2) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ string(3) "foo"
+ }
+ [1]=>
+ &array(1) {
+ [0]=>
+ string(3) "foo"
+ }
+}
+OK
+array(1) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ *RECURSION*
+ }
+ }
+ }
+ }
+}
+OK
+array(2) {
+ ["a"]=>
+ array(2) {
+ ["b"]=>
+ string(1) "c"
+ ["d"]=>
+ string(1) "e"
+ }
+ ["f"]=>
+ array(1) {
+ ["g"]=>
+ string(1) "h"
+ }
+}
+OK
+object(Obj)#%d (3) {
+ ["a"]=>
+ int(1)
+ [%r"?b"?:protected"?%r]=>
+ int(2)
+ [%r"?c"?:("Obj":)?private"?%r]=>
+ int(3)
+}
+OK
+array(2) {
+ [0]=>
+ object(Obj)#%d (3) {
+ ["a"]=>
+ int(1)
+ [%r"?b"?:protected"?%r]=>
+ int(2)
+ [%r"?c"?:("Obj":)?private"?%r]=>
+ int(3)
+ }
+ [1]=>
+ object(Obj)#%d (3) {
+ ["a"]=>
+ int(4)
+ [%r"?b"?:protected"?%r]=>
+ int(5)
+ [%r"?c"?:("Obj":)?private"?%r]=>
+ int(6)
+ }
+}
+OK
+array(2) {
+ [0]=>
+ &object(Obj)#%d (3) {
+ ["a"]=>
+ int(1)
+ [%r"?b"?:protected"?%r]=>
+ int(2)
+ [%r"?c"?:("Obj":)?private"?%r]=>
+ int(3)
+ }
+ [1]=>
+ &object(Obj)#%d (3) {
+ ["a"]=>
+ int(1)
+ [%r"?b"?:protected"?%r]=>
+ int(2)
+ [%r"?c"?:("Obj":)?private"?%r]=>
+ int(3)
+ }
+}
+OK
diff --git a/php/tests/066.phpt b/php/tests/066.phpt
new file mode 100644
index 00000000..d2e430d6
--- /dev/null
+++ b/php/tests/066.phpt
@@ -0,0 +1,70 @@
+--TEST--
+Extra bytes buffered streaming unserialization (single)
+--SKIPIF--
+--FILE--
+feed($str);
+
+ while (true) {
+ if ($unpacker->execute()) {
+ $unserialized = $unpacker->data();
+ var_dump($unserialized);
+ $unpacker->reset();
+ } else {
+ break;
+ }
+ }
+ $i += $len;
+ }
+ }
+}
+
+test('array(1, 2, 3)', array('9301020392'));
+test('array(1, 2, 3), array(3, 9), 4', array('9301020392', '030904'));
+--EXPECTF--
+array(3) {
+ [0]=>
+ int(1)
+ [1]=>
+ int(2)
+ [2]=>
+ int(3)
+}
+array(2) {
+ [0]=>
+ array(3) {
+ [0]=>
+ int(1)
+ [1]=>
+ int(2)
+ [2]=>
+ int(3)
+ }
+ [1]=>
+ array(2) {
+ [0]=>
+ int(3)
+ [1]=>
+ int(9)
+ }
+}
+int(4)
diff --git a/php/tests/067.phpt b/php/tests/067.phpt
new file mode 100644
index 00000000..96c14429
--- /dev/null
+++ b/php/tests/067.phpt
@@ -0,0 +1,74 @@
+--TEST--
+Extra bytes unbuffered streaming unserialization (single)
+--SKIPIF--
+--FILE--
+execute($str, $offset)) {
+ $unserialized = $unpacker->data();
+ var_dump($unserialized);
+
+ $unpacker->reset();
+ $str = substr($str, $offset);
+ $offset = 0;
+ } else {
+ break;
+ }
+ }
+ $i += $len;
+ }
+ }
+}
+
+test('array(1, 2, 3)', array('9301020392'));
+test('array(1, 2, 3), array(3, 9), 4', array('9301020392', '030904'));
+--EXPECTF--
+array(3) {
+ [0]=>
+ int(1)
+ [1]=>
+ int(2)
+ [2]=>
+ int(3)
+}
+array(2) {
+ [0]=>
+ array(3) {
+ [0]=>
+ int(1)
+ [1]=>
+ int(2)
+ [2]=>
+ int(3)
+ }
+ [1]=>
+ array(2) {
+ [0]=>
+ int(3)
+ [1]=>
+ int(9)
+ }
+}
+int(4)
diff --git a/php/tests/070.phpt b/php/tests/070.phpt
index 893023b5..affcc729 100644
--- a/php/tests/070.phpt
+++ b/php/tests/070.phpt
@@ -2,8 +2,8 @@
Check for alias functions
--SKIPIF--
= 0) {
- echo "skip tests in PHP 5.3.2 and lower";
+if (version_compare(PHP_VERSION, '5.3.2') <= 0) {
+ echo "skip tests in PHP 5.3.3 or newer";
}
--FILE--
&array(1) {
[0]=>
- &array(1) {
- [0]=>
- &array(1) {
- [0]=>
- *RECURSION*
- }
- }
+ *RECURSION*
}
}
}
diff --git a/php/tests/070b.phpt b/php/tests/070b.phpt
index 109ddc1a..0aaa4e75 100644
--- a/php/tests/070b.phpt
+++ b/php/tests/070b.phpt
@@ -2,8 +2,8 @@
Check for alias functions
--SKIPIF--
= 0) {
+ echo "skip tests in PHP 5.3.2 or older";
}
--FILE--
&array(1) {
[0]=>
- *RECURSION*
+ &array(1) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ *RECURSION*
+ }
+ }
}
}
}
diff --git a/php/tests/071.phpt b/php/tests/071.phpt
index 431303b6..20041d40 100644
--- a/php/tests/071.phpt
+++ b/php/tests/071.phpt
@@ -2,8 +2,8 @@
Check for class methods
--SKIPIF--
= 0) {
- echo "skip tests in PHP 5.3.2 and lower";
+if (version_compare(PHP_VERSION, '5.3.2') <= 0) {
+ echo "skip tests in PHP 5.3.3 or newer";
}
--FILE--
&array(1) {
[0]=>
- &array(1) {
- [0]=>
- &array(1) {
- [0]=>
- *RECURSION*
- }
- }
+ *RECURSION*
}
}
}
diff --git a/php/tests/071b.phpt b/php/tests/071b.phpt
index 770d06ee..f6630736 100644
--- a/php/tests/071b.phpt
+++ b/php/tests/071b.phpt
@@ -2,8 +2,8 @@
Check for class methods
--SKIPIF--
= 0) {
+ echo "skip tests in PHP 5.3.2 or older";
}
--FILE--
&array(1) {
[0]=>
- *RECURSION*
+ &array(1) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ *RECURSION*
+ }
+ }
}
}
}
diff --git a/php/tests/072.phpt b/php/tests/072.phpt
index ea79a56d..0f89e0ac 100644
--- a/php/tests/072.phpt
+++ b/php/tests/072.phpt
@@ -2,8 +2,8 @@
Check for class methods unpacker
--SKIPIF--
= 0) {
- echo "skip tests in PHP 5.3.2 and lower";
+if (version_compare(PHP_VERSION, '5.3.2') <= 0) {
+ echo "skip tests in PHP 5.3.3 or newer";
}
--FILE--
&array(1) {
[0]=>
- &array(1) {
- [0]=>
- &array(1) {
- [0]=>
- *RECURSION*
- }
- }
+ *RECURSION*
}
}
}
diff --git a/php/tests/072b.phpt b/php/tests/072b.phpt
index c7b0c3ce..05fe41e3 100644
--- a/php/tests/072b.phpt
+++ b/php/tests/072b.phpt
@@ -2,8 +2,8 @@
Check for class methods unpacker
--SKIPIF--
= 0) {
+ echo "skip tests in PHP 5.3.2 or older";
}
--FILE--
&array(1) {
[0]=>
- *RECURSION*
+ &array(1) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ *RECURSION*
+ }
+ }
}
}
}
diff --git a/php/tests/073.phpt b/php/tests/073.phpt
index d3a76379..f6a91a66 100644
--- a/php/tests/073.phpt
+++ b/php/tests/073.phpt
@@ -2,8 +2,8 @@
Check for class unpacker
--SKIPIF--
= 0) {
- echo "skip tests in PHP 5.3.2 and lower";
+if (version_compare(PHP_VERSION, '5.3.2') <= 0) {
+ echo "skip tests in PHP 5.3.3 or newer";
}
--FILE--
&array(1) {
[0]=>
- &array(1) {
- [0]=>
- &array(1) {
- [0]=>
- *RECURSION*
- }
- }
+ *RECURSION*
}
}
}
diff --git a/php/tests/073b.phpt b/php/tests/073b.phpt
index 131a5346..065a2aa1 100644
--- a/php/tests/073b.phpt
+++ b/php/tests/073b.phpt
@@ -2,8 +2,8 @@
Check for class unpacker
--SKIPIF--
= 0) {
+ echo "skip tests in PHP 5.3.2 or older";
}
--FILE--
&array(1) {
[0]=>
- *RECURSION*
+ &array(1) {
+ [0]=>
+ &array(1) {
+ [0]=>
+ *RECURSION*
+ }
+ }
}
}
}