X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-http;a=blobdiff_plain;f=php_http_message.h;h=e45cabf4b42473273500ab40fef3aedd73fe0399;hp=8c6c554bc8cfc636e88f928958d987b926e5fc4f;hb=f753226f1f45e10ef3916256ec1bc0416c8644a8;hpb=66f7e8b6b937976c9c1d3dbfb86a90141b19b5c6 diff --git a/php_http_message.h b/php_http_message.h index 8c6c554..e45cabf 100644 --- a/php_http_message.h +++ b/php_http_message.h @@ -30,7 +30,7 @@ typedef struct php_http_message php_http_message_t; struct php_http_message { PHP_HTTP_INFO_IMPL(http, type) HashTable hdrs; - php_http_message_body_t body; + php_http_message_body_t *body; php_http_message_t *parent; void *opaque; #ifdef ZTS @@ -40,7 +40,7 @@ struct php_http_message { PHP_HTTP_API zend_bool php_http_message_info_callback(php_http_message_t **message, HashTable **headers, php_http_info_t *info TSRMLS_DC); -PHP_HTTP_API php_http_message_t *php_http_message_init(php_http_message_t *m, php_http_message_type_t t TSRMLS_DC); +PHP_HTTP_API php_http_message_t *php_http_message_init(php_http_message_t *m, php_http_message_type_t t, php_http_message_body_t *body TSRMLS_DC); PHP_HTTP_API php_http_message_t *php_http_message_init_env(php_http_message_t *m, php_http_message_type_t t TSRMLS_DC); PHP_HTTP_API php_http_message_t *php_http_message_copy(php_http_message_t *from, php_http_message_t *to); PHP_HTTP_API php_http_message_t *php_http_message_copy_ex(php_http_message_t *from, php_http_message_t *to, zend_bool parents); @@ -50,7 +50,9 @@ PHP_HTTP_API void php_http_message_free(php_http_message_t **message); PHP_HTTP_API void php_http_message_set_type(php_http_message_t *m, php_http_message_type_t t); PHP_HTTP_API void php_http_message_set_info(php_http_message_t *message, php_http_info_t *info); -PHP_HTTP_API zval *php_http_message_header(php_http_message_t *msg, char *key_str, size_t key_len, int join); +PHP_HTTP_API void php_http_message_update_headers(php_http_message_t *msg); + +PHP_HTTP_API zval *php_http_message_header(php_http_message_t *msg, const char *key_str, size_t key_len, int join); PHP_HTTP_API zend_bool php_http_message_is_multipart(php_http_message_t *msg, char **boundary); PHP_HTTP_API void php_http_message_to_string(php_http_message_t *msg, char **string, size_t *length); @@ -59,7 +61,7 @@ PHP_HTTP_API void php_http_message_to_callback(php_http_message_t *msg, php_http PHP_HTTP_API void php_http_message_serialize(php_http_message_t *message, char **string, size_t *length); PHP_HTTP_API php_http_message_t *php_http_message_reverse(php_http_message_t *msg); -PHP_HTTP_API php_http_message_t *php_http_message_interconnect(php_http_message_t *m1, php_http_message_t *m2); +PHP_HTTP_API php_http_message_t *php_http_message_zip(php_http_message_t *one, php_http_message_t *two); #define php_http_message_count(c, m) \ { \ @@ -67,34 +69,36 @@ PHP_HTTP_API php_http_message_t *php_http_message_interconnect(php_http_message_ for (c = 0; __tmp_msg; __tmp_msg = __tmp_msg->parent, ++(c)); \ } -PHP_HTTP_API php_http_message_t *php_http_message_parse(php_http_message_t *msg, const char *str, size_t len TSRMLS_DC); +PHP_HTTP_API php_http_message_t *php_http_message_parse(php_http_message_t *msg, const char *str, size_t len, zend_bool greedy TSRMLS_DC); /* PHP */ typedef struct php_http_message_object { zend_object zo; + zend_object_value zv; php_http_message_t *message; zend_object_value parent, body; zval *iterator; } php_http_message_object_t; -extern zend_class_entry *php_http_message_class_entry; -extern zend_function_entry http_message_method_entry[]; +zend_class_entry *php_http_message_get_class_entry(void); -extern PHP_MINIT_FUNCTION(http_message); -extern PHP_MSHUTDOWN_FUNCTION(http_message); +PHP_MINIT_FUNCTION(http_message); +PHP_MSHUTDOWN_FUNCTION(http_message); -extern void php_http_message_object_prepend(zval *this_ptr, zval *prepend, zend_bool top /* = 1 */ TSRMLS_DC); -extern void php_http_message_object_reverse(zval *this_ptr, zval *return_value TSRMLS_DC); +void php_http_message_object_prepend(zval *this_ptr, zval *prepend, zend_bool top /* = 1 */ TSRMLS_DC); +void php_http_message_object_reverse(zval *this_ptr, zval *return_value TSRMLS_DC); +STATUS php_http_message_object_set_body(php_http_message_object_t *obj, zval *zbody TSRMLS_DC); -extern zend_object_value php_http_message_object_new(zend_class_entry *ce TSRMLS_DC); -extern zend_object_value php_http_message_object_new_ex(zend_class_entry *ce, php_http_message_t *msg, php_http_message_object_t **ptr TSRMLS_DC); -extern zend_object_value php_http_message_object_clone(zval *object TSRMLS_DC); -extern void php_http_message_object_free(void *object TSRMLS_DC); +zend_object_value php_http_message_object_new(zend_class_entry *ce TSRMLS_DC); +zend_object_value php_http_message_object_new_ex(zend_class_entry *ce, php_http_message_t *msg, php_http_message_object_t **ptr TSRMLS_DC); +zend_object_value php_http_message_object_clone(zval *object TSRMLS_DC); +void php_http_message_object_free(void *object TSRMLS_DC); PHP_METHOD(HttpMessage, __construct); PHP_METHOD(HttpMessage, getBody); PHP_METHOD(HttpMessage, setBody); +PHP_METHOD(HttpMessage, addBody); PHP_METHOD(HttpMessage, getHeader); PHP_METHOD(HttpMessage, setHeader); PHP_METHOD(HttpMessage, addHeader); @@ -119,7 +123,8 @@ PHP_METHOD(HttpMessage, guessContentType); PHP_METHOD(HttpMessage, getParentMessage); PHP_METHOD(HttpMessage, send); PHP_METHOD(HttpMessage, toString); -PHP_METHOD(HttpMessage, toMessageTypeObject); +PHP_METHOD(HttpMessage, toStream); +PHP_METHOD(HttpMessage, toCallback); PHP_METHOD(HttpMessage, count); PHP_METHOD(HttpMessage, serialize);