X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=http_send_api.c;h=2be92b62dec675c02fd141aaeb65dc3c30ac0391;hb=13e641e4455b1f86520de7c6390b2b7659d65e54;hp=ebecb33e94fa482ee448b903e01e911cb8c7ff57;hpb=8d1b5913ed5318d9ea4adba8bff3eee7ab782fc0;p=m6w6%2Fext-http diff --git a/http_send_api.c b/http_send_api.c index ebecb33..2be92b6 100644 --- a/http_send_api.c +++ b/http_send_api.c @@ -39,28 +39,8 @@ static inline void _http_flush(void *nothing, const char *data, size_t data_len fprintf(stderr, "Flushing after writing %u bytes\n", (uint) data_len); #endif -#define HTTP_MSEC(s) (s * 1000) -#define HTTP_USEC(s) (HTTP_MSEC(s) * 1000) -#define HTTP_NSEC(s) (HTTP_USEC(s) * 1000) -#define HTTP_NANOSEC (1000 * 1000 * 1000) -#define HTTP_DIFFSEC (0.001) - if (HTTP_G->send.throttle_delay >= HTTP_DIFFSEC) { -#if defined(PHP_WIN32) - Sleep((DWORD) HTTP_MSEC(HTTP_G->send.throttle_delay)); -#elif defined(HAVE_USLEEP) - usleep(HTTP_USEC(HTTP_G->send.throttle_delay)); -#elif defined(HAVE_NANOSLEEP) - struct timespec req, rem; - - req.tv_sec = (time_t) HTTP_G->send.throttle_delay; - req.tv_nsec = HTTP_NSEC(HTTP_G->send.throttle_delay) % HTTP_NANOSEC; - - while (nanosleep(&req, &rem) && (errno == EINTR) && (HTTP_NSEC(rem.tv_sec) + rem.tv_nsec) > HTTP_NSEC(HTTP_DIFFSEC))) { - req.tv_sec = rem.tv_sec; - req.tv_nsec = rem.tv_nsec; - } -#endif + http_sleep(HTTP_G->send.throttle_delay); } } /* }}} */ @@ -85,7 +65,7 @@ static inline void _http_send_response_start(void **buffer, size_t content_lengt #define http_send_response_data_plain(b, d, dl) _http_send_response_data_plain((b), (d), (dl) TSRMLS_CC) static inline void _http_send_response_data_plain(void **buffer, const char *data, size_t data_len TSRMLS_DC) { - if (HTTP_G->send.deflate.encoding) { + if (HTTP_G->send.deflate.encoding && *(http_encoding_stream **) buffer) { #ifdef HTTP_HAVE_ZLIB char *encoded; size_t encoded_len; @@ -157,7 +137,7 @@ static inline void _http_send_response_data_fetch(void **buffer, const void *dat #define http_send_response_finish(b) _http_send_response_finish((b) TSRMLS_CC) static inline void _http_send_response_finish(void **buffer TSRMLS_DC) { - if (HTTP_G->send.deflate.encoding) { + if (HTTP_G->send.deflate.encoding && *(http_encoding_stream **) buffer) { #ifdef HTTP_HAVE_ZLIB char *encoded = NULL; size_t encoded_len = 0;