ID: 35895 User updated by: f dot hardy at origami-systems dot com Reported By: f dot hardy at origami-systems dot com -Status: No Feedback +Status: Open Bug Type: Scripting Engine problem Operating System: Freebsd 6 PHP Version: 5.1.2 New Comment:
Bug is always alive in php 5.1.5 under freebsd 6.0. Previous Comments: ------------------------------------------------------------------------ [2006-06-18 17:43:46] jona at oismail dot com Reproduced on Windows 2000 when using __sleept() with aggregated objects as private memembers. The bug has been reproduced in both PHP 5.2-dev (from link below) and PHP 5.1.4. The following script can be used to reproduce the error: <?php class TestParent { private $parentPrivateVar; protected $parentProtectedVar; public $parentPublicVar; public function __construct($private, $protected, $public) { $this->parentPrivateVar = $private; $this->parentProtectedVar = $protected; $this->parentPublicVar = $public; } function __sleep() { return array("parentPrivateVar", "parentProtectedVar", "parentPublicVar"); } } class TestChild extends TestParent { private $childPrivateVar; protected $childProtectedVar; public $childPublicVar; public function __construct($private, $protected, $public) { $this->childPrivateVar = "child_". $private; $this->childProtectedVar = "child_". $protected; $this->childPublicVar = "child_". $public; parent::__construct("parent_". $private, "parent_". $protected, "parent_". $public); } function __sleep() { return array_merge(array("childPrivateVar", "childProtectedVar", "childPublicVar"), parent::__sleep() ); } } class WebSession { private $privateVar; private $privateAggregatedObject; public function __construct($private, TestChild &$o) { $this->privateVar = $private; $this->privateAggregatedObject = $o; } public function __sleep() { return array("privateVar", "privateAggregatedObject"); } public function getPrivateVar() { return $this->privateVar; } public function getObject() { return $this->privateAggregatedObject; } } // Report simple running errors error_reporting(E_ERROR | E_PARSE | E_WARNING | E_NOTICE | E_STRICT | E_USER_ERROR | E_USER_WARNING | E_USER_NOTICE); // Start user session session_start(); if(isset($_SESSION['obj_Info']) === false) { $_SESSION['obj_Info'] = new WebSession("private variable", new TestChild("private", "protected", "public") ); } echo "<pre>"; var_dump($_SESSION['obj_Info']); echo "</pre>"; echo "<hr />"; echo "TEST: ". $_SESSION['obj_Info']->getPrivateVar() ."<br />"; echo "OBJECT: ". $_SESSION['obj_Info']->getObject() ."<br />"; echo "OBJECT PUBLIC VAR: ". $_SESSION['obj_Info']->getObject()->childPublicVar ."<br />"; ?> GIVES THE FOLLOWING OUTPUT IN PHP 5.1.4: object(WebSession)#1 (2) { ["privateVar:private"]=> string(16) "private variable" ["privateAggregatedObject:private"]=> object(TestChild)#2 (6) { ["childPrivateVar:private"]=> string(13) "child_private" ["childProtectedVar:protected"]=> string(15) "child_protected" ["childPublicVar"]=> string(12) "child_public" ["parentPrivateVar:private"]=> string(14) "parent_private" ["parentProtectedVar:protected"]=> string(16) "parent_protected" ["parentPublicVar"]=> string(13) "parent_public" } } TEST: private variable OBJECT: Object id #2 OBJECT PUBLIC VAR: child_public Notice: Unknown: "parentPrivateVar" returned as member variable from __sleep() but does not exist in Unknown on line 0 The notice is only thrown on the initial run with "parentPrivateVar" is actually set. The notice is not thrown if "parentPrivateVar" is null. In PHP 5.2-dev the scrip dies line 76: echo "OBJECT: ". $_SESSION['obj_Info']->getObject() ."<br />"; The notice is still thrown when "parentPrivateVar" is set though. ------------------------------------------------------------------------ [2006-05-31 01:00:00] php-bugs at lists dot php dot net No feedback was provided for this bug for over a week, so it is being suspended automatically. If you are able to provide the information that was originally requested, please do so and change the status of the bug back to "Open". ------------------------------------------------------------------------ [2006-05-23 17:54:08] [EMAIL PROTECTED] Please try using this CVS snapshot: http://snaps.php.net/php5.2-latest.tar.gz For Windows: http://snaps.php.net/win32/php5.2-win32-latest.zip I cannot reproduce (on Linux) using latest 5.2 CVS. Can you please try a snapshot from the 5.2 series and let me know if it's fixed for you there? ------------------------------------------------------------------------ [2006-05-23 17:27:58] f dot hardy at origami-systems dot com Bug is still alive in php 5.1.4 under freebsd. Please correct it ! ------------------------------------------------------------------------ [2006-01-28 01:00:04] php-bugs at lists dot php dot net No feedback was provided for this bug for over a week, so it is being suspended automatically. If you are able to provide the information that was originally requested, please do so and change the status of the bug back to "Open". ------------------------------------------------------------------------ The remainder of the comments for this report are too long. To view the rest of the comments, please view the bug report online at http://bugs.php.net/35895 -- Edit this bug report at http://bugs.php.net/?id=35895&edit=1