mirror of
https://github.com/php/php-src.git
synced 2025-08-15 21:48:51 +02:00
- MFH Fix issue with destruction of overloaded objects
This commit is contained in:
parent
0edbdd7680
commit
ce2f9bb0cf
4 changed files with 24 additions and 9 deletions
|
@ -122,8 +122,8 @@ ZEND_API zend_object_handle zend_objects_store_put(void *object, zend_objects_st
|
|||
obj->object = object;
|
||||
obj->dtor = dtor?dtor:(zend_objects_store_dtor_t)zend_objects_destroy_object;
|
||||
obj->free_storage = free_storage;
|
||||
|
||||
obj->clone = clone;
|
||||
obj->handlers = NULL;
|
||||
|
||||
#if ZEND_DEBUG_OBJECTS
|
||||
fprintf(stderr, "Allocated object id #%d\n", handle);
|
||||
|
@ -168,7 +168,7 @@ ZEND_API void zend_objects_store_del_ref(zval *zobject TSRMLS_DC)
|
|||
handle = Z_OBJ_HANDLE_P(zobject);
|
||||
|
||||
Z_ADDREF_P(zobject);
|
||||
zend_objects_store_del_ref_by_handle(handle TSRMLS_CC);
|
||||
zend_objects_store_del_ref_by_handle_ex(handle, Z_OBJ_HT_P(zobject) TSRMLS_CC);
|
||||
Z_DELREF_P(zobject);
|
||||
|
||||
GC_ZOBJ_CHECK_POSSIBLE_ROOT(zobject);
|
||||
|
@ -177,7 +177,7 @@ ZEND_API void zend_objects_store_del_ref(zval *zobject TSRMLS_DC)
|
|||
/*
|
||||
* Delete a reference to an objects store entry given the object handle.
|
||||
*/
|
||||
ZEND_API void zend_objects_store_del_ref_by_handle(zend_object_handle handle TSRMLS_DC)
|
||||
ZEND_API void zend_objects_store_del_ref_by_handle_ex(zend_object_handle handle, const zend_object_handlers *handlers TSRMLS_DC) /* {{{ */
|
||||
{
|
||||
struct _store_object *obj;
|
||||
int failure = 0;
|
||||
|
@ -198,6 +198,9 @@ 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) {
|
||||
if (handlers && !obj->handlers) {
|
||||
obj->handlers = handlers;
|
||||
}
|
||||
zend_try {
|
||||
obj->dtor(obj->object, handle TSRMLS_CC);
|
||||
} zend_catch {
|
||||
|
@ -232,6 +235,7 @@ ZEND_API void zend_objects_store_del_ref_by_handle(zend_object_handle handle TSR
|
|||
zend_bailout();
|
||||
}
|
||||
}
|
||||
/* }}} */
|
||||
|
||||
ZEND_API zend_object_value zend_objects_store_clone_obj(zval *zobject TSRMLS_DC)
|
||||
{
|
||||
|
@ -250,6 +254,7 @@ ZEND_API zend_object_value zend_objects_store_clone_obj(zval *zobject TSRMLS_DC)
|
|||
|
||||
retval.handle = zend_objects_store_put(new_object, obj->dtor, obj->free_storage, obj->clone TSRMLS_CC);
|
||||
retval.handlers = Z_OBJ_HT_P(zobject);
|
||||
EG(objects_store).object_buckets[handle].bucket.obj.handlers = retval.handlers;
|
||||
|
||||
return retval;
|
||||
}
|
||||
|
@ -288,8 +293,10 @@ 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_object_handle handle = Z_OBJ_HANDLE_P(zobject);
|
||||
|
||||
EG(objects_store).object_buckets[handle].destructor_called = 1;
|
||||
zend_object_store_bucket *obj_bucket = &EG(objects_store).object_buckets[handle];
|
||||
|
||||
obj_bucket->bucket.obj.handlers = Z_OBJ_HT_P(zobject);;
|
||||
obj_bucket->destructor_called = 1;
|
||||
}
|
||||
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue