X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-http;a=blobdiff_plain;f=php_http_request_pool_api.h;h=1ae2056cb969cd30c00d049c7a2444066168299e;hp=d1ab0b3d1ce4b26087ebc1fd9a49bd6c75f09a88;hb=f2d0dbf38d7b00455d3dfba8f2de087105ae0f35;hpb=63ae3bdd3dc28be356bb0680a16bce2090b7847b diff --git a/php_http_request_pool_api.h b/php_http_request_pool_api.h index d1ab0b3..1ae2056 100644 --- a/php_http_request_pool_api.h +++ b/php_http_request_pool_api.h @@ -29,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);