andrey          Sat Aug 21 09:49:19 2004 EDT

  Modified files:              
    /php-src/tests/classes      bug26737.phpt 
    /php-src/ext/standard       var.c 
  Log:
  fix for bug 26737 : private & protected member variables not serialized
  when user defined __sleep() is declared. Additionally E_NOTICE is
  being thrown if __sleep() returns a non-existing member variable name 
  
  
http://cvs.php.net/diff.php/php-src/tests/classes/bug26737.phpt?r1=1.2&r2=1.3&ty=u
Index: php-src/tests/classes/bug26737.phpt
diff -u php-src/tests/classes/bug26737.phpt:1.2 php-src/tests/classes/bug26737.phpt:1.3
--- php-src/tests/classes/bug26737.phpt:1.2     Thu Jul 22 14:40:19 2004
+++ php-src/tests/classes/bug26737.phpt Sat Aug 21 09:49:19 2004
@@ -10,12 +10,13 @@
 
        public function __sleep()
        {
-               return array('private', 'protected', 'public');
+               return array('private', 'protected', 'public', 'no_such');
        }
 }
 $foo = new foo();
 $data = serialize($foo);
 var_dump(str_replace("\0", '\0', $data));
 ?>
---EXPECT--
-string(76) 
"O:3:"foo":3:{s:7:"private";N;s:9:"protected";R:2;s:6:"public";s:6:"public";}"
+--EXPECTF--
+Notice: serialize(): "no_such" returned as member variable from __sleep() but does 
not exist in %s on line %d
+string(130) 
"O:3:"foo":4:{s:12:"\0foo\0private";s:7:"private";s:12:"\0*\0protected";s:9:"protected";s:6:"public";s:6:"public";s:7:"no_such";N;}"
http://cvs.php.net/diff.php/php-src/ext/standard/var.c?r1=1.191&r2=1.192&ty=u
Index: php-src/ext/standard/var.c
diff -u php-src/ext/standard/var.c:1.191 php-src/ext/standard/var.c:1.192
--- php-src/ext/standard/var.c:1.191    Sun Jul  4 07:14:17 2004
+++ php-src/ext/standard/var.c  Sat Aug 21 09:49:19 2004
@@ -18,7 +18,7 @@
    +----------------------------------------------------------------------+
 */
 
-/* $Id: var.c,v 1.191 2004/07/04 11:14:17 helly Exp $ */
+/* $Id: var.c,v 1.192 2004/08/21 13:49:19 andrey Exp $ */
 
 
 /* {{{ includes 
@@ -578,14 +578,40 @@
                                smart_str_appendl(buf,"N;", 2);
                                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_intern(buf, d, var_hash TSRMLS_CC);  
 
+                               php_var_serialize_string(buf, Z_STRVAL_PP(name), 
Z_STRLEN_PP(name));
+                               php_var_serialize_intern(buf, d, var_hash TSRMLS_CC);
                        } else {
-                               php_var_serialize_intern(buf, &nvalp, var_hash 
TSRMLS_CC);      
+                               zend_class_entry *ce;
+                               ce = zend_get_class_entry(*struc TSRMLS_CC);
+                               if (ce) {
+                                       char *prot_name, *priv_name;
+                                       int prop_name_length;
+                                       
+                                       do {
+                                               zend_mangle_property_name(&priv_name, 
&prop_name_length, ce->name, ce->name_length, 
+                                                                       
Z_STRVAL_PP(name), Z_STRLEN_PP(name) + 1, ce->type & ZEND_INTERNAL_CLASS);
+                                               if 
(zend_hash_find(Z_OBJPROP_PP(struc), priv_name, prop_name_length, (void *) &d) == 
SUCCESS) {
+                                                       php_var_serialize_string(buf, 
priv_name, prop_name_length-1);
+                                                       php_var_serialize_intern(buf, 
d, var_hash TSRMLS_CC);
+                                                       break;
+                                               }
+                                               zend_mangle_property_name(&prot_name, 
&prop_name_length,  "*", 1, 
+                                                                       
Z_STRVAL_PP(name), Z_STRLEN_PP(name) + 1, ce->type & ZEND_INTERNAL_CLASS);
+                                               if 
(zend_hash_find(Z_OBJPROP_PP(struc), prot_name, prop_name_length, (void *) &d) == 
SUCCESS) {
+                                                       php_var_serialize_string(buf, 
prot_name, prop_name_length - 1);
+                                                       php_var_serialize_intern(buf, 
d, var_hash TSRMLS_CC);
+                                                       break;
+                                               }
+                                               php_error_docref(NULL TSRMLS_CC, 
E_NOTICE, "\"%s\" returned as member variable from __sleep() but does not exist", 
Z_STRVAL_PP(name));
+                                               php_var_serialize_string(buf, 
Z_STRVAL_PP(name), Z_STRLEN_PP(name));
+                                               php_var_serialize_intern(buf, &nvalp, 
var_hash TSRMLS_CC);
+                                       } while (0);
+                               } else {
+                                       php_var_serialize_string(buf, 
Z_STRVAL_PP(name), Z_STRLEN_PP(name));
+                                       php_var_serialize_intern(buf, &nvalp, var_hash 
TSRMLS_CC);
+                               }
                        }
                }
        }

-- 
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to