X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-http;a=blobdiff_plain;f=php_http_message_body.h;h=55016b7f830ed765dfb7b3affcd353b0cb261ae8;hp=165dc3f04342318ecb61ce27e8e98d932ce129b6;hb=87702149e0c422104aec0ddb7391f91392be0376;hpb=86c77c2966b90f63ad5b6991733ab036d33a976d diff --git a/php_http_message_body.h b/php_http_message_body.h index 165dc3f..55016b7 100644 --- a/php_http_message_body.h +++ b/php_http_message_body.h @@ -17,6 +17,7 @@ typedef struct php_http_message_body { int stream_id; php_stream_statbuf ssb; char *boundary; + unsigned refcount; #ifdef ZTS void ***ts; #endif @@ -24,8 +25,9 @@ typedef struct php_http_message_body { struct php_http_message; -PHP_HTTP_API php_http_message_body_t *php_http_message_body_init(php_http_message_body_t *body, php_stream *stream TSRMLS_DC); -PHP_HTTP_API php_http_message_body_t *php_http_message_body_copy(php_http_message_body_t *from, php_http_message_body_t *to, zend_bool dup_internal_stream_and_contents); +PHP_HTTP_API php_http_message_body_t *php_http_message_body_init(php_http_message_body_t **body, php_stream *stream TSRMLS_DC); +PHP_HTTP_API unsigned php_http_message_body_addref(php_http_message_body_t *body); +PHP_HTTP_API php_http_message_body_t *php_http_message_body_copy(php_http_message_body_t *from, php_http_message_body_t *to); PHP_HTTP_API STATUS php_http_message_body_add_form(php_http_message_body_t *body, HashTable *fields, HashTable *files); PHP_HTTP_API STATUS php_http_message_body_add_form_field(php_http_message_body_t *body, const char *name, const char *value_str, size_t value_len); PHP_HTTP_API STATUS php_http_message_body_add_form_file(php_http_message_body_t *body, const char *name, const char *ctype, const char *file, php_stream *stream); @@ -35,7 +37,6 @@ PHP_HTTP_API size_t php_http_message_body_appendf(php_http_message_body_t *body, PHP_HTTP_API void php_http_message_body_to_string(php_http_message_body_t *body, char **buf, size_t *len, off_t offset, size_t forlen); PHP_HTTP_API void php_http_message_body_to_stream(php_http_message_body_t *body, php_stream *s, off_t offset, size_t forlen); PHP_HTTP_API void php_http_message_body_to_callback(php_http_message_body_t *body, php_http_pass_callback_t cb, void *cb_arg, off_t offset, size_t forlen); -PHP_HTTP_API void php_http_message_body_dtor(php_http_message_body_t *body); PHP_HTTP_API void php_http_message_body_free(php_http_message_body_t **body); PHP_HTTP_API const php_stream_statbuf *php_http_message_body_stat(php_http_message_body_t *body); #define php_http_message_body_size(b) (php_http_message_body_stat((b))->sb.st_size) @@ -54,6 +55,7 @@ static inline php_stream *php_http_message_body_stream(php_http_message_body_t * typedef struct php_http_message_body_object { zend_object zo; php_http_message_body_t *body; + unsigned shared:1; } php_http_message_body_object_t; zend_class_entry *php_http_message_body_get_class_entry(void);