summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ext/standard/tests/serialize/002.phpt6
-rw-r--r--ext/standard/var.c29
2 files changed, 18 insertions, 17 deletions
diff --git a/ext/standard/tests/serialize/002.phpt b/ext/standard/tests/serialize/002.phpt
index 30de5fa621..7b83c28a63 100644
--- a/ext/standard/tests/serialize/002.phpt
+++ b/ext/standard/tests/serialize/002.phpt
@@ -27,8 +27,10 @@ var_dump($t);
?>
--EXPECT--
__sleep called
-O:1:"t":1:{s:1:"a";s:5:"hello";}
-object(t)(1) {
+O:1:"t":2:{s:1:"a";s:5:"hello";s:1:"b";N;}
+object(t)(2) {
["a"]=>
string(5) "hello"
+ ["b"]=>
+ NULL
}
diff --git a/ext/standard/var.c b/ext/standard/var.c
index 52c6c1f81f..a765abf975 100644
--- a/ext/standard/var.c
+++ b/ext/standard/var.c
@@ -199,24 +199,29 @@ static void php_var_serialize_class(smart_str *buf, zval **struc, zval *retval_p
php_var_serialize_class_name(buf, struc TSRMLS_CC);
+ smart_str_append_long(buf, count);
+ smart_str_appendl(buf, ":{", 2);
+
if (count > 0) {
char *key;
zval **d, **name;
ulong index;
HashPosition pos;
int i;
- int cundef;
- smart_str buf2={0};
-
- cundef=0;
+ zval nval, *nvalp;
+
+ ZVAL_NULL(&nval);
+ nvalp = &nval;
+
zend_hash_internal_pointer_reset_ex(HASH_OF(retval_ptr), &pos);
+
for (;; zend_hash_move_forward_ex(HASH_OF(retval_ptr), &pos)) {
i = zend_hash_get_current_key_ex(HASH_OF(retval_ptr), &key, NULL,
&index, 0, &pos);
if (i == HASH_KEY_NON_EXISTANT)
break;
-
+
zend_hash_get_current_data_ex(HASH_OF(retval_ptr),
(void **) &name, &pos);
@@ -227,22 +232,16 @@ static void php_var_serialize_class(smart_str *buf, zval **struc, zval *retval_p
continue;
}
+ php_var_serialize_string(buf, Z_STRVAL_PP(name), Z_STRLEN_PP(name));
+
if (zend_hash_find(Z_OBJPROP_PP(struc), Z_STRVAL_PP(name),
Z_STRLEN_PP(name) + 1, (void *) &d) == SUCCESS) {
- php_var_serialize_string(&buf2, Z_STRVAL_PP(name),
- Z_STRLEN_PP(name));
- php_var_serialize_intern(&buf2, d, var_hash TSRMLS_CC);
+ php_var_serialize_intern(buf, d, var_hash TSRMLS_CC);
} else {
- cundef++;
+ php_var_serialize_intern(buf, &nvalp, var_hash TSRMLS_CC);
}
}
- smart_str_append_long(buf, count-cundef);
- smart_str_appendl(buf, ":{", 2);
- smart_str_appendl(buf,buf2.c,buf2.len);
- smart_str_free(&buf2);
}
-
-
smart_str_appendc(buf, '}');
}