Index: ext/mysqli/mysqli.c =================================================================== RCS file: /repository/php-src/ext/mysqli/mysqli.c,v retrieving revision 1.70 diff -u -p -d -r1.70 mysqli.c --- ext/mysqli/mysqli.c 22 Jun 2005 09:12:43 -0000 1.70 +++ ext/mysqli/mysqli.c 27 Jun 2005 15:44:15 -0000 @@ -123,11 +123,23 @@ void php_clear_mysql(MY_MYSQL *mysql) { static void mysqli_objects_free_storage(zend_object *object TSRMLS_DC) { mysqli_object *intern = (mysqli_object *)object; - MYSQLI_RESOURCE *my_res = (MYSQLI_RESOURCE *)intern->ptr; zend_hash_destroy(intern->zo.properties); FREE_HASHTABLE(intern->zo.properties); + efree(object); +} +/* }}} */ + +/* {{{ mysqli_objects_destroy_object + */ +static void mysqli_objects_destroy_object(void *object, zend_object_handle handle TSRMLS_DC) +{ + mysqli_object *intern = (mysqli_object *)object; + MYSQLI_RESOURCE *my_res = (MYSQLI_RESOURCE *)intern->ptr; + + zend_objects_destroy_object(object, handle TSRMLS_CC); + /* link object */ if (instanceof_function(intern->zo.ce, mysqli_link_class_entry TSRMLS_CC)) { if (my_res && my_res->ptr) { @@ -155,8 +167,8 @@ static void mysqli_objects_free_storage( php_clear_warnings((MYSQLI_WARNING *)my_res->info); } } + intern->ptr = NULL; my_efree(my_res); - efree(object); } /* }}} */ @@ -354,7 +366,7 @@ PHP_MYSQLI_EXPORT(zend_object_value) mys zend_hash_copy(intern->zo.properties, &class_type->default_properties, (copy_ctor_func_t) zval_add_ref, (void *) &tmp, sizeof(zval *)); - retval.handle = zend_objects_store_put(intern, (zend_objects_store_dtor_t) zend_objects_destroy_object, (zend_objects_free_object_storage_t) mysqli_objects_free_storage, NULL TSRMLS_CC); + retval.handle = zend_objects_store_put(intern, (zend_objects_store_dtor_t) mysqli_objects_destroy_object, (zend_objects_free_object_storage_t) mysqli_objects_free_storage, NULL TSRMLS_CC); retval.handlers = &mysqli_object_handlers; return retval;