diff options
| author | Dmitry Stogov <dmitry@php.net> | 2006-05-31 12:59:45 +0000 |
|---|---|---|
| committer | Dmitry Stogov <dmitry@php.net> | 2006-05-31 12:59:45 +0000 |
| commit | 75fac72dc52ab24aaa14a2a1b520752961099044 (patch) | |
| tree | 032d1af2b1ce226f10bc96ffd122a707e012457c | |
| parent | 4b2d974691096d44ae72e9704cdbe4f54447f21a (diff) | |
| download | php-git-75fac72dc52ab24aaa14a2a1b520752961099044.tar.gz | |
Support for nested exceptions and fatal errors in destructors
| -rw-r--r-- | Zend/zend_objects.c | 3 | ||||
| -rw-r--r-- | Zend/zend_objects_API.c | 16 |
2 files changed, 16 insertions, 3 deletions
diff --git a/Zend/zend_objects.c b/Zend/zend_objects.c index 2827a2892f..8f4e59474e 100644 --- a/Zend/zend_objects.c +++ b/Zend/zend_objects.c @@ -103,9 +103,10 @@ ZEND_API void zend_objects_destroy_object(zend_object *object, zend_object_handl zval *file = zend_read_property(default_exception_ce, old_exception, "file", sizeof("file")-1, 1 TSRMLS_CC); zval *line = zend_read_property(default_exception_ce, old_exception, "line", sizeof("line")-1, 1 TSRMLS_CC); + zval_ptr_dtor(&EG(exception)); + EG(exception) = old_exception; zend_error(E_ERROR, "Ignoring exception from %v::__destruct() while an exception is already active (Uncaught %v in %R on line %ld)", object->ce->name, Z_OBJCE_P(old_exception)->name, Z_TYPE_P(file), Z_UNIVAL_P(file), Z_LVAL_P(line)); - zval_ptr_dtor(&EG(exception)); } EG(exception) = old_exception; } diff --git a/Zend/zend_objects_API.c b/Zend/zend_objects_API.c index b40a6f845a..08b50a9260 100644 --- a/Zend/zend_objects_API.c +++ b/Zend/zend_objects_API.c @@ -173,6 +173,7 @@ ZEND_API void zend_objects_store_del_ref(zval *zobject TSRMLS_DC) ZEND_API void zend_objects_store_del_ref_by_handle(zend_object_handle handle TSRMLS_DC) { struct _store_object *obj; + int failure = 0; if (!EG(objects_store).object_buckets) { return; @@ -190,12 +191,20 @@ ZEND_API void zend_objects_store_del_ref_by_handle(zend_object_handle handle TSR EG(objects_store).object_buckets[handle].destructor_called = 1; if (obj->dtor) { - obj->dtor(obj->object, handle TSRMLS_CC); + zend_try { + obj->dtor(obj->object, handle TSRMLS_CC); + } zend_catch { + failure = 1; + } zend_end_try(); } } if (obj->refcount == 1) { if (obj->free_storage) { - obj->free_storage(obj->object TSRMLS_CC); + zend_try { + obj->free_storage(obj->object TSRMLS_CC); + } zend_catch { + failure = 1; + } zend_end_try(); } ZEND_OBJECTS_STORE_ADD_TO_FREE_LIST(); } @@ -211,6 +220,9 @@ ZEND_API void zend_objects_store_del_ref_by_handle(zend_object_handle handle TSR fprintf(stderr, "Decreased refcount of object id #%d\n", handle); } #endif + if (failure) { + zend_bailout(); + } } ZEND_API zend_object_value zend_objects_store_clone_obj(zval *zobject TSRMLS_DC) |
