From: Antony Dovgal Date: Tue, 15 Nov 2005 14:08:03 +0000 (+0000) Subject: MFH: call zend_objects_destroy_object() explicitly X-Git-Tag: php-5.1.0RC5~17 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=23a3fdbf048c9bc4e772d1c64352b797187f1d96;p=php MFH: call zend_objects_destroy_object() explicitly fix segfault when intern->time is NULL --- diff --git a/ext/date/php_date.c b/ext/date/php_date.c index dc2765b8b4..f737b4305f 100644 --- a/ext/date/php_date.c +++ b/ext/date/php_date.c @@ -1024,7 +1024,7 @@ static zend_object_value date_object_new_date(zend_class_entry *class_type TSRML memset(intern, 0, sizeof(php_date_obj)); intern->std.ce = class_type; - retval.handle = zend_objects_store_put(intern, NULL, (zend_objects_free_object_storage_t) date_object_free_storage_date, NULL TSRMLS_CC); + retval.handle = zend_objects_store_put(intern, (zend_objects_store_dtor_t)zend_objects_destroy_object, (zend_objects_free_object_storage_t) date_object_free_storage_date, NULL TSRMLS_CC); retval.handlers = &date_object_handlers_date; return retval; @@ -1039,7 +1039,7 @@ static zend_object_value date_object_new_timezone(zend_class_entry *class_type T memset(intern, 0, sizeof(php_timezone_obj)); intern->std.ce = class_type; - retval.handle = zend_objects_store_put(intern, NULL, (zend_objects_free_object_storage_t) date_object_free_storage_timezone, NULL TSRMLS_CC); + retval.handle = zend_objects_store_put(intern, (zend_objects_store_dtor_t)zend_objects_destroy_object, (zend_objects_free_object_storage_t) date_object_free_storage_timezone, NULL TSRMLS_CC); retval.handlers = &date_object_handlers_timezone; return retval; @@ -1049,10 +1049,12 @@ static void date_object_free_storage_date(void *object TSRMLS_DC) { php_date_obj *intern = (php_date_obj *)object; - if (intern->time->tz_info) { - timelib_tzinfo_dtor(intern->time->tz_info); + if (intern->time) { + if (intern->time->tz_info) { + timelib_tzinfo_dtor(intern->time->tz_info); + } + timelib_time_dtor(intern->time); } - timelib_time_dtor(intern->time); efree(object); }