X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-http;a=blobdiff_plain;f=php_http_request_pool_api.h;h=78dbdb2f01a948835082e6d61ad7f28f3b34caac;hp=e9ea75cb8eafe00b90cda3b87180b7cc10ca5dd4;hb=45abbc6fd229be01e963e9642a03118d3c99131c;hpb=e83a7438dc70ed96630887246a1d3aefcf155b1c diff --git a/php_http_request_pool_api.h b/php_http_request_pool_api.h index e9ea75c..78dbdb2 100644 --- a/php_http_request_pool_api.h +++ b/php_http_request_pool_api.h @@ -16,28 +16,39 @@ #define PHP_HTTP_REQUEST_POOL_API_H #ifdef HTTP_HAVE_CURL -#include "php_http_std_defs.h" -#include "php_http_request_api.h" -#include "phpstr/phpstr.h" - -#ifdef PHP_WIN32 -# include -#endif - -#include - typedef struct { CURLM *ch; zend_llist finished; zend_llist handles; - zend_llist bodies; int unfinished; } http_request_pool; #define http_request_pool_responsehandler _http_request_pool_responsehandler extern void _http_request_pool_responsehandler(zval **req, CURL *ch TSRMLS_DC); -#define http_request_pool_requesthandler(r, b) _http_request_pool_requesthandler((r), (b) TSRMLS_CC) -extern STATUS _http_request_pool_requesthandler(zval *request, http_request_body *body TSRMLS_DC); + +#define http_request_pool_try \ + { \ + zval *old_exception = EG(exception); \ + EG(exception) = NULL; +#define http_request_pool_catch() \ + if (EG(exception)) { \ + http_request_pool_wrap_exception(old_exception, EG(exception)); \ + } else { \ + EG(exception) = old_exception; \ + } \ + } +#define http_request_pool_final() \ + if (EG(exception)) { \ + zval *exception; \ + http_request_pool_wrap_exception(NULL, EG(exception)); \ + exception = EG(exception); \ + EG(exception) = NULL; \ + zend_throw_exception_object(exception TSRMLS_CC); \ + } + +#define http_request_pool_wrap_exception(o, n) _http_request_pool_wrap_exception((o), (n) TSRMLS_CC) +extern void _http_request_pool_wrap_exception(zval *old_exception, zval *new_exception TSRMLS_DC); + #define http_request_pool_init(p) _http_request_pool_init((p) TSRMLS_CC) PHP_HTTP_API http_request_pool *_http_request_pool_init(http_request_pool *pool TSRMLS_DC);