X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-http;a=blobdiff_plain;f=php_http_env_response.c;h=097bdba7217845025377f3cbad8b1186563bb19e;hp=67a6d5830e4bf4d07b63b7db7b5b1df4b108050c;hb=693770d1c7ec8f618c56907574e53a0eb1a7d68e;hpb=789f8205b16e89ce1982e4d492c7406e8ff66271 diff --git a/php_http_env_response.c b/php_http_env_response.c index 67a6d58..097bdba 100644 --- a/php_http_env_response.c +++ b/php_http_env_response.c @@ -229,8 +229,9 @@ php_http_cache_status_t php_http_env_is_response_cached_by_last_modified(zval *o static zend_bool php_http_env_response_is_cacheable(php_http_env_response_t *r, php_http_message_t *request) { TSRMLS_FETCH_FROM_CTX(r->ts); + long status = r->ops->get_status(r); - if (r->ops->get_status(r) >= 400) { + if (status && status / 100 != 2) { return 0; } @@ -1212,9 +1213,14 @@ static PHP_METHOD(HttpEnvResponse, __invoke) PHP_HTTP_ENV_RESPONSE_OBJECT_INIT(obj); - php_http_message_object_init_body_object(obj); + if (!obj->body) { + php_http_message_object_init_body_object(obj); + } php_http_message_body_append(obj->message->body, ob_str, ob_len); #if PHP_VERSION_ID >= 50400 + if (ob_flags & PHP_OUTPUT_HANDLER_CLEAN) { + php_stream_truncate_set_size(php_http_message_body_stream(obj->message->body), 0); + } RETURN_TRUE; #else RETURN_EMPTY_STRING();