ho derick... could you read over this mail, i plan to send to php-dev-ml. i'm not sure if i used the correct words.. you know.. my english :)) thanx... vvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvvv hello... i'm new here on this ML. some of you might know me. but thats not the reason for my email. I implemented a new feature, derick kindly commited for me last night. Ok... if you unserialize serialized Objects, and their classes still are undefined, you'll get an "__PHP_Incomplete_Class"-Object. To get another chance to define the used class to instanziate the serialized Objects, you (now) can set an unserialie_callback_function to add (include) the missing classdefinition. Because there is an option to autostart the session, there could be no chance to set the callback function, so i decided to use a PG() which could be set in php.ini, .htaccess or by ini_set(), before php starts unserialize your sessiondata. OK.. Why don't you include all classes could ever appear in your serialized strings (or sessions)?? The reason is simple.. large projects often contains a large number of objects.. but not (always) all of them are needed at simultaniously. I think it saves work and time to get (for any not yet defined classes) a callbackfunction started (with the undefined class's name as parameter) which can define the wanted class. So you can automate the loading of all classes really used. a short example: php.ini: ... unserialize_callback_func= ... test.php: <?php // callback_function function callback($classname='') { $classes=array('xml_tree_node'=>'Node.php','base_source'=>'libs/standard/base_source.php'); if (file_exists($classes[$classname])) include_once($classes[$classname]); } // $r => string contains serialized Objects $r='O:13:"xml_tree_node":4:{s:10:"attributes";a:1:{s:4:"size";i:1;}s:8:"children";a:1:{i:0;O:13:"xml_tree_node":4:{s:10:"attributes";a:0:{}s:8:"children";a:1:{i:0;O:11:"base_source":2:{s:4:"name";s:9:"base_text";s:8:"children";s:8:"Tree.php";}}s:7:"content";s:0:"";s:4:"name";s:3:"pre";}}s:7:"content";s:0:"";s:4:"name";s:7:"bt_font";}'; $a=unserialize($r); ini_set('unserialize_callback_func','callback'); $b=unserialize($r); ?> $a then contains "__PHP_Incomplete_Class"es, but while "unserialize($b)" the callback_function (here: callback()) will be called twice: once with "xml_tree_node" and once with "base_source" as parameter. callback() then includes the corresponding php-class-definitions. if 'unserialize_callback_func' remains unset, the "__PHP_Incomplete_Class" will be returned. If a specified callback function soesn't exist, a warning will be returned. Another warning appears, if the specified function exists, but doesn't define the function it was called for. i hope you understood description (bad english) and are agree with my implementation. And i hope (too), you aren't angry with me because i told derick to commit that patch before a great deal of discussion was started. regards ---bernd roemer--- (fumanchi) PS.: it'll be nice if anyone could tell me what type of documentation i should write on that new feature. -- PHP Development Mailing List <http://www.php.net/> To unsubscribe, e-mail: [EMAIL PROTECTED] For additional commands, e-mail: [EMAIL PROTECTED] To contact the list administrators, e-mail: [EMAIL PROTECTED]