summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarcus Boerger <helly@php.net>2004-07-25 17:25:44 +0000
committerMarcus Boerger <helly@php.net>2004-07-25 17:25:44 +0000
commitf5cf052225ff4bc5ba7fe2c8b9f0ffcd980cac6f (patch)
treea6280e2650b8a147f09e61feb7aaf393ef9790f4
parentba5587132538294c0fd22853d50b84a22a453cb7 (diff)
downloadphp-git-f5cf052225ff4bc5ba7fe2c8b9f0ffcd980cac6f.tar.gz
- Fix bug #29368 : The destructor is called when an exception is thrown from the constructor
-rw-r--r--Zend/zend_execute.c3
-rw-r--r--Zend/zend_objects_API.c9
-rw-r--r--Zend/zend_objects_API.h1
3 files changed, 13 insertions, 0 deletions
diff --git a/Zend/zend_execute.c b/Zend/zend_execute.c
index 9d997576ea..1c84067d1d 100644
--- a/Zend/zend_execute.c
+++ b/Zend/zend_execute.c
@@ -2777,6 +2777,9 @@ int zend_do_fcall_common_helper(ZEND_OPCODE_HANDLER_ARGS)
if (EG(This)) {
if (EG(exception) && EX(fbc) && EX(fbc)->common.fn_flags&ZEND_ACC_CTOR) {
EG(This)->refcount--;
+ if (EG(This)->refcount == 1) {
+ zend_object_store_ctor_failed(EG(This) TSRMLS_CC);
+ }
zval_ptr_dtor(&EG(This));
} else if (should_change_scope) {
zval_ptr_dtor(&EG(This));
diff --git a/Zend/zend_objects_API.c b/Zend/zend_objects_API.c
index a5788bd437..33225da4db 100644
--- a/Zend/zend_objects_API.c
+++ b/Zend/zend_objects_API.c
@@ -207,6 +207,15 @@ ZEND_API void zend_object_store_set_object(zval *zobject, void *object TSRMLS_DC
}
+/* Called when the ctor was terminated by an exception */
+ZEND_API void zend_object_store_ctor_failed(zval *zobject TSRMLS_DC)
+{
+ zend_object_handle handle = Z_OBJ_HANDLE_P(zobject);
+
+ EG(objects_store).object_buckets[handle].destructor_called = 1;
+}
+
+
/* Proxy objects workings */
typedef struct _zend_proxy_object {
zval *object;
diff --git a/Zend/zend_objects_API.h b/Zend/zend_objects_API.h
index bcca11b0f2..189ab9c5ec 100644
--- a/Zend/zend_objects_API.h
+++ b/Zend/zend_objects_API.h
@@ -68,6 +68,7 @@ ZEND_API zend_object_value zend_objects_store_clone_obj(zval *object TSRMLS_DC);
ZEND_API void *zend_object_store_get_object(zval *object TSRMLS_DC);
/* See comment in zend_objects_API.c before you use this */
ZEND_API void zend_object_store_set_object(zval *zobject, void *object TSRMLS_DC);
+ZEND_API void zend_object_store_ctor_failed(zval *zobject TSRMLS_DC);
ZEND_API void zend_objects_store_free_object_storage(zend_objects_store *objects TSRMLS_DC);