From: Yasuo Ohgaki Date: Thu, 2 May 2002 06:50:18 +0000 (+0000) Subject: Fixed header output. Only need to output header when it is actually sent to client. X-Git-Tag: php-4.3.0dev-ZendEngine2-Preview1~307 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=1103311eee7ac19515aafdffda44dad7635f841b;p=php Fixed header output. Only need to output header when it is actually sent to client. --- diff --git a/main/output.c b/main/output.c index 288b7c0469..093519f342 100644 --- a/main/output.c +++ b/main/output.c @@ -211,9 +211,6 @@ PHPAPI void php_end_ob_buffer(zend_bool send_buffer, zend_bool just_flush TSRMLS if (SG(headers_sent) && !SG(request_info).headers_only) { OG(php_body_write) = php_ub_body_write_no_header; } else { - /* Set Content-Length only if unerasable */ - if (!OG(active_ob_buffer).erase && status == (PHP_OUTPUT_HANDLER_START|PHP_OUTPUT_HANDLER_END)) - ADD_CL_HEADER(OG(active_ob_buffer).text_length); OG(php_body_write) = php_ub_body_write; } } @@ -242,6 +239,9 @@ PHPAPI void php_end_ob_buffer(zend_bool send_buffer, zend_bool just_flush TSRMLS OG(ob_nesting_level)--; if (send_buffer) { + /* FIXME: It's better to make it work with the last buffer */ + if (OG(ob_nesting_level) == 1 && status == (PHP_OUTPUT_HANDLER_START|PHP_OUTPUT_HANDLER_END)) + ADD_CL_HEADER(final_buffer_length); OG(php_body_write)(final_buffer, final_buffer_length TSRMLS_CC); }