X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-http;a=blobdiff_plain;f=php_http_object.c;h=e42998ea773407c830ac3cb9282a3ade55cd7081;hp=b8589f5aec07b5bc267f781f891c6a2048ae020d;hb=f00dec5b0217c81cf9d71d96103106fdaf2ab310;hpb=03f11ce599fa5a89148d588caf6ccec7f939e9d4 diff --git a/php_http_object.c b/php_http_object.c index b8589f5..e42998e 100644 --- a/php_http_object.c +++ b/php_http_object.c @@ -12,6 +12,8 @@ #include "php_http_api.h" +static zend_object_handlers php_http_object_handlers; + zend_object *php_http_object_new(zend_class_entry *ce) { return &php_http_object_new_ex(ce, NULL)->zo; @@ -21,16 +23,21 @@ php_http_object_t *php_http_object_new_ex(zend_class_entry *ce, void *intern) { php_http_object_t *o; - o = ecalloc(1, sizeof(php_http_object_t) + (ce->default_properties_count - 1) * sizeof(zval)); + o = ecalloc(1, sizeof(*o) + zend_object_properties_size(ce)); zend_object_std_init(&o->zo, ce); object_properties_init(&o->zo, ce); o->intern = intern; - o->zo.handlers = zend_get_std_object_handlers(); + o->zo.handlers = &php_http_object_handlers; return o; } +void php_http_object_free(zend_object *object) +{ + zend_object_std_dtor(object); +} + ZEND_RESULT_CODE php_http_new(void **obj_ptr, zend_class_entry *ce, php_http_new_t create, zend_class_entry *parent_ce, void *intern_ptr) { void *obj; @@ -49,31 +56,75 @@ ZEND_RESULT_CODE php_http_new(void **obj_ptr, zend_class_entry *ce, php_http_new return SUCCESS; } -ZEND_RESULT_CODE php_http_method_call(zval *object, const char *method_str, size_t method_len, int argc, zval argv[], zval *retval_ptr) +php_http_object_method_t *php_http_object_method_init(php_http_object_method_t *cb, zval *zobject, const char *method_str, size_t method_len) +{ + if (!cb) { + cb = ecalloc(1, sizeof(*cb)); + } else { + memset(cb, 0, sizeof(*cb)); + } + + cb->fci.size = sizeof(cb->fci); + ZVAL_STRINGL(&cb->fci.function_name, method_str, method_len); + cb->fcc.initialized = 1; + cb->fcc.calling_scope = cb->fcc.called_scope = Z_OBJCE_P(zobject); + cb->fcc.function_handler = Z_OBJ_HT_P(zobject)->get_method(&Z_OBJ_P(zobject), Z_STR(cb->fci.function_name), NULL); + + return cb; +} + +void php_http_object_method_dtor(php_http_object_method_t *cb) +{ + zval_ptr_dtor(&cb->fci.function_name); +} + +void php_http_object_method_free(php_http_object_method_t **cb) +{ + if (*cb) { + php_http_object_method_dtor(*cb); + efree(*cb); + *cb = NULL; + } +} + +ZEND_RESULT_CODE php_http_object_method_call(php_http_object_method_t *cb, zval *zobject, zval *retval_ptr, int argc, zval *args) { - zend_fcall_info fci; - zval *retval; ZEND_RESULT_CODE rv; + zval retval; + + ZVAL_UNDEF(&retval); + Z_ADDREF_P(zobject); + cb->fci.object = Z_OBJ_P(zobject); + cb->fcc.object = Z_OBJ_P(zobject); - fci.size = sizeof(fci); - fci.object = Z_OBJ_P(object); - fci.retval = retval_ptr ? retval_ptr : &retval; - fci.param_count = argc; - fci.params = argv; - fci.no_separation = 1; - fci.symbol_table = NULL; - fci.function_table = NULL; + cb->fci.retval = retval_ptr ? retval_ptr : &retval; + + cb->fci.param_count = argc; + cb->fci.params = args; + + if (cb->fcc.called_scope != Z_OBJCE_P(zobject)) { + cb->fcc.called_scope = Z_OBJCE_P(zobject); + cb->fcc.function_handler = Z_OBJ_HT_P(zobject)->get_method(&Z_OBJ_P(zobject), Z_STR(cb->fci.function_name), NULL); + } - ZVAL_STRINGL(&fci.function_name, method_str, method_len); - rv = zend_call_function(&fci, NULL TSRMLS_CC); - zval_ptr_dtor(&fci.function_name); + rv = zend_call_function(&cb->fci, &cb->fcc); - if (!retval_ptr && retval) { + zval_ptr_dtor(zobject); + if (!retval_ptr && !Z_ISUNDEF(retval)) { zval_ptr_dtor(&retval); } + return rv; } +PHP_MINIT_FUNCTION(http_object) +{ + memcpy(&php_http_object_handlers, zend_get_std_object_handlers(), sizeof(php_http_object_handlers)); + php_http_object_handlers.offset = XtOffsetOf(php_http_object_t, zo); + + return SUCCESS; +} + /* * Local variables: * tab-width: 4