X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-http;a=blobdiff_plain;f=php_http_request_pool_api.h;h=1ae2056cb969cd30c00d049c7a2444066168299e;hp=e9ea75cb8eafe00b90cda3b87180b7cc10ca5dd4;hb=f2d0dbf38d7b00455d3dfba8f2de087105ae0f35;hpb=e83a7438dc70ed96630887246a1d3aefcf155b1c diff --git a/php_http_request_pool_api.h b/php_http_request_pool_api.h index e9ea75c..1ae2056 100644 --- a/php_http_request_pool_api.h +++ b/php_http_request_pool_api.h @@ -16,16 +16,6 @@ #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; @@ -39,6 +29,30 @@ 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);