X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-http;a=blobdiff_plain;f=php_http_headers_api.h;h=dbf1a439e3bb0cc5cda26b5ad8939228e31dfa26;hp=b02e4c8923c5b6b90de902e35e09f16780537f0f;hb=39feb7a7e30bb4b393a6f76aa2f35d4e9275523e;hpb=0d925a2820b9d75b8e32c451fd400863e51e22fe diff --git a/php_http_headers_api.h b/php_http_headers_api.h index b02e4c8..dbf1a43 100644 --- a/php_http_headers_api.h +++ b/php_http_headers_api.h @@ -21,12 +21,20 @@ #include "php_http_std_defs.h" #include "php_http_info_api.h" +#define HTTP_REDIRECT 302L +#define HTTP_REDIRECT_PERM 301L +#define HTTP_REDIRECT_POST 303L +#define HTTP_REDIRECT_TEMP 307L + typedef enum { RANGE_OK, RANGE_NO, RANGE_ERR } http_range_status; +#define http_headers_global_init() _http_headers_global_init(INIT_FUNC_ARGS_PASSTHRU) +extern STATUS _http_headers_global_init(INIT_FUNC_ARGS); + #define http_parse_headers(h, a) _http_parse_headers_ex((h), Z_ARRVAL_P(a), 1, http_info_default_callback, NULL TSRMLS_CC) #define http_parse_headers_ex(h, ht, p) _http_parse_headers_ex((h), (ht), (p), http_info_default_callback, NULL TSRMLS_CC) #define http_parse_headers_cb(h, ht, p, f, d) _http_parse_headers_ex((h), (ht), (p), (f), (d) TSRMLS_CC) @@ -36,12 +44,19 @@ PHP_HTTP_API STATUS _http_parse_headers_ex(const char *header, HashTable *header #define http_get_request_headers_ex(h, p) _http_get_request_headers_ex((h), (p) TSRMLS_CC) PHP_HTTP_API void _http_get_request_headers_ex(HashTable *headers, zend_bool prettify TSRMLS_DC); -#define http_negotiate_language(zsupported, def) http_negotiate_language_ex(Z_ARRVAL_P(zsupported), (def)) -#define http_negotiate_language_ex(supported, def) http_negotiate_q("HTTP_ACCEPT_LANGUAGE", (supported), (def)) -#define http_negotiate_charset(zsupported, def) http_negotiate_charset_ex(Z_ARRVAL_P(zsupported), (def)) -#define http_negotiate_charset_ex(supported, def) http_negotiate_q("HTTP_ACCEPT_CHARSET", (supported), (def)) -#define http_negotiate_q(e, s, d) _http_negotiate_q((e), (s), (d) TSRMLS_CC) -PHP_HTTP_API char *_http_negotiate_q(const char *entry, const HashTable *supported, const char *def TSRMLS_DC); +typedef char *(*negotiate_func_t)(const char *test, double *quality, HashTable *supported TSRMLS_DC); + +#define http_negotiate_language_func _http_negotiate_language_func +extern char *_http_negotiate_language_func(const char *test, double *quality, HashTable *supported TSRMLS_DC); +#define http_negotiate_charset_func _http_negotiate_charset_func +extern char *_http_negotiate_charset_func(const char *test, double *quality, HashTable *supported TSRMLS_DC); + +#define http_negotiate_language(zsupported) http_negotiate_language_ex(Z_ARRVAL_P(zsupported)) +#define http_negotiate_language_ex(supported) http_negotiate_q("HTTP_ACCEPT_LANGUAGE", (supported), http_negotiate_language_func) +#define http_negotiate_charset(zsupported) http_negotiate_charset_ex(Z_ARRVAL_P(zsupported)) +#define http_negotiate_charset_ex(supported) http_negotiate_q("HTTP_ACCEPT_CHARSET", (supported), http_negotiate_charset_func) +#define http_negotiate_q(e, s, n) _http_negotiate_q((e), (s), (n) TSRMLS_CC) +PHP_HTTP_API HashTable *_http_negotiate_q(const char *header, HashTable *supported, negotiate_func_t neg TSRMLS_DC); #define http_get_request_ranges(r, l) _http_get_request_ranges((r), (l) TSRMLS_CC) PHP_HTTP_API http_range_status _http_get_request_ranges(HashTable *ranges, size_t length TSRMLS_DC);