tony2001 Mon Jun 27 14:22:00 2005 EDT
Modified files: (Branch: PHP_5_0)
/php-src NEWS
/php-src/ext/mysqli mysqli.c
Log:
MFH: fix #33491 (crash after extending MySQLi internal class)
http://cvs.php.net/diff.php/php-src/NEWS?r1=1.1760.2.443&r2=1.1760.2.444&ty=u
Index: php-src/NEWS
diff -u php-src/NEWS:1.1760.2.443 php-src/NEWS:1.1760.2.444
--- php-src/NEWS:1.1760.2.443 Fri Jun 24 04:45:41 2005
+++ php-src/NEWS Mon Jun 27 14:21:57 2005
@@ -14,6 +14,7 @@
- Fixed memory corruption in ImageTTFText() with 64bit systems. (Andrey)
- Fixed memory corruption in stristr(). (Derick)
- Fixed segfaults when CURL callback functions throw exception. (Tony)
+- Fixed bug #33491 (crash after extending MySQLi internal class). (Tony)
- Fixed bug #33340 (CLI Crash when calling php:function from XSLT). (Rob)
- Fixed bug #33277 (private method accessed by child class). (Dmitry)
- Fixed bug #33268 (iconv_strlen() works only with a parameter of < 3 in
http://cvs.php.net/diff.php/php-src/ext/mysqli/mysqli.c?r1=1.43.2.16&r2=1.43.2.17&ty=u
Index: php-src/ext/mysqli/mysqli.c
diff -u php-src/ext/mysqli/mysqli.c:1.43.2.16
php-src/ext/mysqli/mysqli.c:1.43.2.17
--- php-src/ext/mysqli/mysqli.c:1.43.2.16 Thu May 5 09:30:31 2005
+++ php-src/ext/mysqli/mysqli.c Mon Jun 27 14:22:00 2005
@@ -15,7 +15,7 @@
| Author: Georg Richter <[EMAIL PROTECTED]> |
+----------------------------------------------------------------------+
- $Id: mysqli.c,v 1.43.2.16 2005/05/05 13:30:31 georg Exp $
+ $Id: mysqli.c,v 1.43.2.17 2005/06/27 18:22:00 tony2001 Exp $
*/
#ifdef HAVE_CONFIG_H
@@ -120,17 +120,28 @@
static void mysqli_objects_free_storage(zend_object *object TSRMLS_DC)
{
mysqli_object *intern = (mysqli_object *)object;
+
+ zend_objects_free_object_storage(&(intern->zo) TSRMLS_CC);
+}
+/* }}} */
+
+/* {{{ 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_hash_destroy(intern->zo.properties);
- FREE_HASHTABLE(intern->zo.properties);
+ 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) {
MY_MYSQL *mysql = (MY_MYSQL *)my_res->ptr;
-
- mysql_close(mysql->mysql);
+
+ if (mysql->mysql) {
+ mysql_close(mysql->mysql);
+ }
php_clear_mysql(mysql);
efree(mysql);
@@ -146,8 +157,8 @@
mysql_free_result(my_res->ptr);
}
}
+ intern->ptr = NULL;
my_efree(my_res);
- efree(object);
}
/* }}} */
@@ -331,7 +342,7 @@
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;
--
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php