dmitry Mon Jul 10 12:46:28 2006 UTC
Modified files: (Branch: PHP_5_2)
/php-src/ext/mysqli mysqli.c
Log:
Another fix for #38019
http://cvs.php.net/viewvc.cgi/php-src/ext/mysqli/mysqli.c?r1=1.72.2.16.2.7&r2=1.72.2.16.2.8&diff_format=u
Index: php-src/ext/mysqli/mysqli.c
diff -u php-src/ext/mysqli/mysqli.c:1.72.2.16.2.7
php-src/ext/mysqli/mysqli.c:1.72.2.16.2.8
--- php-src/ext/mysqli/mysqli.c:1.72.2.16.2.7 Mon Jul 10 10:05:20 2006
+++ php-src/ext/mysqli/mysqli.c Mon Jul 10 12:46:28 2006
@@ -15,7 +15,7 @@
| Author: Georg Richter <[EMAIL PROTECTED]> |
+----------------------------------------------------------------------+
- $Id: mysqli.c,v 1.72.2.16.2.7 2006/07/10 10:05:20 dmitry Exp $
+ $Id: mysqli.c,v 1.72.2.16.2.8 2006/07/10 12:46:28 dmitry Exp $
*/
#ifdef HAVE_CONFIG_H
@@ -132,53 +132,79 @@
}
/* }}} */
-/* {{{ mysqli_objects_destroy_object
+/* {{{ mysqli_objects_free_storage
*/
-static void mysqli_objects_destroy_object(zend_object *object,
zend_object_handle handle TSRMLS_DC)
+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_objects_destroy_object(object, handle TSRMLS_CC);
+ my_efree(my_res);
+ zend_object_std_dtor(&intern->zo TSRMLS_CC);
+ efree(intern);
+}
+/* }}} */
- /* link object */
- if (instanceof_function(intern->zo.ce, mysqli_link_class_entry
TSRMLS_CC)) {
- if (my_res && my_res->ptr) {
- MY_MYSQL *mysql = (MY_MYSQL *)my_res->ptr;
- if (mysql->mysql) {
- mysql_close(mysql->mysql);
- }
- php_clear_mysql(mysql);
- efree(mysql);
- my_res->ptr = NULL;
- }
- } else if (instanceof_function(intern->zo.ce, mysqli_stmt_class_entry
TSRMLS_CC)) { /* stmt object */
- if (my_res && my_res->ptr) {
- MY_STMT *stmt = (MY_STMT *)my_res->ptr;
- php_clear_stmt_bind(stmt);
- }
- } else if (instanceof_function(intern->zo.ce, mysqli_result_class_entry
TSRMLS_CC)) { /* result object */
- if (my_res && my_res->ptr) {
- mysql_free_result(my_res->ptr);
- }
- } else if (instanceof_function(intern->zo.ce,
mysqli_warning_class_entry TSRMLS_CC)) { /* warning object */
- if (my_res && my_res->ptr) {
- php_clear_warnings((MYSQLI_WARNING *)my_res->info);
+/* {{{ mysqli_link_free_storage
+ */
+static void mysqli_link_free_storage(zend_object *object TSRMLS_DC)
+{
+ mysqli_object *intern = (mysqli_object *)object;
+ MYSQLI_RESOURCE *my_res = (MYSQLI_RESOURCE *)intern->ptr;
+
+ if (my_res && my_res->ptr) {
+ MY_MYSQL *mysql = (MY_MYSQL *)my_res->ptr;
+ if (mysql->mysql) {
+ mysql_close(mysql->mysql);
}
+ php_clear_mysql(mysql);
+ efree(mysql);
}
+ mysqli_objects_free_storage(object TSRMLS_CC);
}
/* }}} */
-/* {{{ mysqli_objects_free_storage
+/* {{{ mysqli_stmt_free_storage
*/
-static void mysqli_objects_free_storage(zend_object *object TSRMLS_DC)
+static void mysqli_stmt_free_storage(zend_object *object TSRMLS_DC)
{
mysqli_object *intern = (mysqli_object *)object;
MYSQLI_RESOURCE *my_res = (MYSQLI_RESOURCE *)intern->ptr;
- my_efree(my_res);
- zend_object_std_dtor(&intern->zo TSRMLS_CC);
- efree(intern);
+ if (my_res && my_res->ptr) {
+ MY_STMT *stmt = (MY_STMT *)my_res->ptr;
+ php_clear_stmt_bind(stmt);
+ }
+ mysqli_objects_free_storage(object TSRMLS_CC);
+}
+/* }}} */
+
+/* {{{ mysqli_result_free_storage
+ */
+static void mysqli_result_free_storage(zend_object *object TSRMLS_DC)
+{
+ mysqli_object *intern = (mysqli_object *)object;
+ MYSQLI_RESOURCE *my_res = (MYSQLI_RESOURCE *)intern->ptr;
+
+ if (my_res && my_res->ptr) {
+ mysql_free_result(my_res->ptr);
+ }
+ mysqli_objects_free_storage(object TSRMLS_CC);
+}
+/* }}} */
+
+/* {{{ mysqli_warning_free_storage
+ */
+static void mysqli_warning_free_storage(zend_object *object TSRMLS_DC)
+{
+ mysqli_object *intern = (mysqli_object *)object;
+ MYSQLI_RESOURCE *my_res = (MYSQLI_RESOURCE *)intern->ptr;
+
+ if (my_res && my_res->ptr) {
+ php_clear_warnings((MYSQLI_WARNING *)my_res->info);
+ my_res->ptr = NULL;
+ }
+ mysqli_objects_free_storage(object TSRMLS_CC);
}
/* }}} */
@@ -343,6 +369,7 @@
mysqli_object *intern;
zval *tmp;
zend_class_entry *mysqli_base_class;
+ zend_objects_free_object_storage_t free_storage;
intern = emalloc(sizeof(mysqli_object));
memset(intern, 0, sizeof(mysqli_object));
@@ -361,7 +388,20 @@
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) mysqli_objects_destroy_object,
(zend_objects_free_object_storage_t) mysqli_objects_free_storage, NULL
TSRMLS_CC);
+ /* link object */
+ if (instanceof_function(class_type, mysqli_link_class_entry TSRMLS_CC))
{
+ free_storage = mysqli_link_free_storage;
+ } else if (instanceof_function(class_type, mysqli_stmt_class_entry
TSRMLS_CC)) { /* stmt object */
+ free_storage = mysqli_stmt_free_storage;
+ } else if (instanceof_function(class_type, mysqli_result_class_entry
TSRMLS_CC)) { /* result object */
+ free_storage = mysqli_result_free_storage;
+ } else if (instanceof_function(class_type, mysqli_warning_class_entry
TSRMLS_CC)) { /* warning object */
+ free_storage = mysqli_warning_free_storage;
+ } else {
+ free_storage = mysqli_objects_free_storage;
+ }
+
+ retval.handle = zend_objects_store_put(intern,
(zend_objects_store_dtor_t) zend_objects_destroy_object, free_storage, NULL
TSRMLS_CC);
retval.handlers = &mysqli_object_handlers;
return retval;
--
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php