diff options
author | Dmitry Stogov <dmitry@zend.com> | 2014-02-10 10:04:30 +0400 |
---|---|---|
committer | Dmitry Stogov <dmitry@zend.com> | 2014-02-10 10:04:30 +0400 |
commit | f4cfaf36e23ca47da3e352e1c60909104c059647 (patch) | |
tree | 0db3e2a323b12c5bbf1a958c857f92eb58c240d1 /Zend/zend_objects_API.h | |
parent | 89a9acea1f9d821a9805b3857bf4febbba08690d (diff) | |
download | php-git-f4cfaf36e23ca47da3e352e1c60909104c059647.tar.gz |
Use better data structures (incomplete)
Diffstat (limited to 'Zend/zend_objects_API.h')
-rw-r--r-- | Zend/zend_objects_API.h | 79 |
1 files changed, 41 insertions, 38 deletions
diff --git a/Zend/zend_objects_API.h b/Zend/zend_objects_API.h index d8f2c5e384..9c69e97ed4 100644 --- a/Zend/zend_objects_API.h +++ b/Zend/zend_objects_API.h @@ -24,32 +24,35 @@ #include "zend.h" -typedef void (*zend_objects_store_dtor_t)(void *object, zend_object_handle handle TSRMLS_DC); -typedef void (*zend_objects_free_object_storage_t)(void *object TSRMLS_DC); -typedef void (*zend_objects_store_clone_t)(void *object, void **object_clone TSRMLS_DC); +//???typedef void (*zend_objects_store_dtor_t)(zend_object *object TSRMLS_DC); +//???typedef void (*zend_objects_free_object_storage_t)(void *object TSRMLS_DC); +//???typedef void (*zend_objects_store_clone_t)(zend_object *object, zend_object **object_clone TSRMLS_DC); -typedef struct _zend_object_store_bucket { - zend_bool destructor_called; - zend_bool valid; - zend_uchar apply_count; - union _store_bucket { - struct _store_object { - void *object; - zend_objects_store_dtor_t dtor; - zend_objects_free_object_storage_t free_storage; - zend_objects_store_clone_t clone; - const zend_object_handlers *handlers; - zend_uint refcount; - gc_root_buffer *buffered; - } obj; - struct { - int next; - } free_list; - } bucket; -} zend_object_store_bucket; +//???typedef union _zend_object_store_bucket { +//??? zend_object *object; +//??? int next_free; +//??? zend_bool destructor_called; +//??? zend_bool valid; +//??? zend_uchar apply_count; +//??? union _store_bucket { +//??? struct _store_object { +//??? zend_object *object; +//??? zend_objects_store_dtor_t dtor; +//??? zend_objects_free_object_storage_t free_storage; +//??? zend_objects_store_clone_t clone; +//??? const zend_object_handlers *handlers; +//??? zend_uint refcount; +//??? gc_root_buffer *buffered; +//??? } obj; +//??? zend_object *obj; +//??? struct { +//??? int next; +//??? } free_list; +//??? } bucket; +//???} zend_object_store_bucket; typedef struct _zend_objects_store { - zend_object_store_bucket *object_buckets; + zend_object **object_buckets; zend_uint top; zend_uint size; int free_list_head; @@ -63,28 +66,28 @@ ZEND_API void zend_objects_store_mark_destructed(zend_objects_store *objects TSR ZEND_API void zend_objects_store_destroy(zend_objects_store *objects); /* Store API functions */ -ZEND_API zend_object_handle zend_objects_store_put(void *object, zend_objects_store_dtor_t dtor, zend_objects_free_object_storage_t storage, zend_objects_store_clone_t clone TSRMLS_DC); +ZEND_API void zend_objects_store_put(zend_object *object TSRMLS_DC); -ZEND_API void zend_objects_store_add_ref(zval *object TSRMLS_DC); -ZEND_API void zend_objects_store_del_ref(zval *object TSRMLS_DC); -ZEND_API void zend_objects_store_add_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); -static zend_always_inline void zend_objects_store_del_ref_by_handle(zend_object_handle handle TSRMLS_DC) { - zend_objects_store_del_ref_by_handle_ex(handle, NULL TSRMLS_CC); -} -ZEND_API zend_uint zend_objects_store_get_refcount(zval *object TSRMLS_DC); -ZEND_API zend_object_value zend_objects_store_clone_obj(zval *object TSRMLS_DC); -ZEND_API void *zend_object_store_get_object(const zval *object TSRMLS_DC); -ZEND_API void *zend_object_store_get_object_by_handle(zend_object_handle handle TSRMLS_DC); +//???ZEND_API void zend_objects_store_add_ref(zval *object TSRMLS_DC); +//???ZEND_API void zend_objects_store_del_ref(zval *object TSRMLS_DC); +//???ZEND_API void zend_objects_store_add_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); +//???static zend_always_inline void zend_objects_store_del_ref_by_handle(zend_object_handle handle TSRMLS_DC) { +//??? zend_objects_store_del_ref_by_handle_ex(handle, NULL TSRMLS_CC); +//???} +//???ZEND_API zend_uint zend_objects_store_get_refcount(zval *object TSRMLS_DC); +//???ZEND_API zend_object *zend_objects_store_clone_obj(zval *object TSRMLS_DC); +//???ZEND_API void *zend_object_store_get_object(const zval *object TSRMLS_DC); +//???ZEND_API void *zend_object_store_get_object_by_handle(zend_object_handle handle 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_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); -#define ZEND_OBJECTS_STORE_HANDLERS zend_objects_store_add_ref, zend_objects_store_del_ref, zend_objects_store_clone_obj +#define ZEND_OBJECTS_STORE_HANDLERS zend_object_free, zend_object_std_dtor, zend_objects_clone_obj -ZEND_API zval *zend_object_create_proxy(zval *object, zval *member TSRMLS_DC); +ZEND_API zend_object *zend_object_create_proxy(zval *object, zval *member TSRMLS_DC); ZEND_API zend_object_handlers *zend_get_std_object_handlers(void); END_EXTERN_C() |