]> granicus.if.org Git - php/commitdiff
MFH: call zend_objects_destroy_object() explicitly
authorAntony Dovgal <tony2001@php.net>
Tue, 15 Nov 2005 14:08:03 +0000 (14:08 +0000)
committerAntony Dovgal <tony2001@php.net>
Tue, 15 Nov 2005 14:08:03 +0000 (14:08 +0000)
fix segfault when intern->time is NULL

ext/date/php_date.c

index dc2765b8b4f3f0c3f25c78260cfd27ed2a6d754c..f737b4305f99a025b0db7ce2d73ff8ae9e555e8c 100644 (file)
@@ -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);
 }