X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-http;a=blobdiff_plain;f=php_http_message_api.h;h=e3ab8397a53ca8c6d425e6157c75112cd0ce50d5;hp=37ccb2ce89475fe30152795839ed97e81100dd3e;hb=669d2e6a8bdc642b6b52693f4593f199ddd7e8d2;hpb=32e91737086db53bb1fd9ed9f79d693c43ec459f diff --git a/php_http_message_api.h b/php_http_message_api.h index 37ccb2c..e3ab839 100644 --- a/php_http_message_api.h +++ b/php_http_message_api.h @@ -17,15 +17,15 @@ #include "php_http_info_api.h" -typedef enum { +typedef enum _http_message_type_t { HTTP_MSG_NONE = 0, HTTP_MSG_REQUEST = IS_HTTP_REQUEST, HTTP_MSG_RESPONSE = IS_HTTP_RESPONSE, } http_message_type; -typedef struct _http_message http_message; +typedef struct _http_message_t http_message; -struct _http_message { +struct _http_message_t { phpstr body; HashTable hdrs; http_message_type type; @@ -48,17 +48,26 @@ PHP_HTTP_API http_message *_http_message_init_ex(http_message *m, http_message_t #define http_message_set_type(m, t) _http_message_set_type((m), (t)) PHP_HTTP_API void _http_message_set_type(http_message *m, http_message_type t); +#define http_message_set_info(m, i) _http_message_set_info((m), (i)) +PHP_HTTP_API void _http_message_set_info(http_message *message, http_info *info); + #define http_message_header(m, h) _http_message_header_ex((m), (h), sizeof(h)) #define http_message_header_ex _http_message_header_ex static inline zval *_http_message_header_ex(http_message *msg, char *key_str, size_t key_len) { zval **header; - if (SUCCESS == zend_hash_find(&msg->hdrs, key_str, key_len, (void **) &header)) { + if (SUCCESS == zend_hash_find(&msg->hdrs, key_str, key_len, (void *) &header)) { return *header; } return NULL; } +#define http_message_count(c, m) \ +{ \ + http_message *__tmp_msg = (m); \ + for (c = 0; __tmp_msg; __tmp_msg = __tmp_msg->parent, ++(c)); \ +} + #define http_message_parse(m, l) http_message_parse_ex(NULL, (m), (l)) #define http_message_parse_ex(h, m, l) _http_message_parse_ex((h), (m), (l) ZEND_FILE_LINE_CC ZEND_FILE_LINE_EMPTY_CC TSRMLS_CC) #define http_message_parse_rel(h, m, l) _http_message_parse_ex((h), (m), (l) ZEND_FILE_LINE_RELAY_CC ZEND_FILE_LINE_ORIG_RELAY_CC TSRMLS_CC) @@ -70,6 +79,12 @@ PHP_HTTP_API void _http_message_tostring(http_message *msg, char **string, size_ #define http_message_serialize(m, s, l) _http_message_serialize((m), (s), (l)) PHP_HTTP_API void _http_message_serialize(http_message *message, char **string, size_t *length); +#define http_message_reverse(m) _http_message_reverse(m) +PHP_HTTP_API http_message *_http_message_reverse(http_message *msg); + +#define http_message_interconnect(m1, m2) _http_message_interconnect((m1), (m2)) +PHP_HTTP_API http_message *_http_message_interconnect(http_message *m1, http_message *m2); + #define http_message_tostruct_recursive(m, s) _http_message_tostruct_recursive((m), (s) TSRMLS_CC) PHP_HTTP_API void _http_message_tostruct_recursive(http_message *msg, zval *strct TSRMLS_DC);