summaryrefslogtreecommitdiff
path: root/main/output.c
diff options
context:
space:
mode:
authorZeev Suraski <zeev@php.net>2001-03-06 16:25:14 +0000
committerZeev Suraski <zeev@php.net>2001-03-06 16:25:14 +0000
commit20d2432c867730adc7c0b199fb971359defb1a53 (patch)
tree99e3a0b0b22cec168913a282106c78663d766dd3 /main/output.c
parent13a97fefeb0ca24813e6646a943cf1f52849c257 (diff)
downloadphp-git-20d2432c867730adc7c0b199fb971359defb1a53.tar.gz
Fix internal output buffering
Diffstat (limited to 'main/output.c')
-rw-r--r--main/output.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/main/output.c b/main/output.c
index 02c8575617..6055439725 100644
--- a/main/output.c
+++ b/main/output.c
@@ -195,6 +195,10 @@ PHPAPI void php_end_ob_buffer(zend_bool send_buffer, zend_bool just_flush)
to_be_destroyed_buffer = OG(active_ob_buffer).buffer;
if (!just_flush) {
+ if (OG(active_ob_buffer).internal_output_handler
+ && (internal_output_handler_buffer != OG(active_ob_buffer).internal_output_handler_buffer)) {
+ efree(internal_output_handler_buffer);
+ }
if (OG(nesting_level)>1) { /* restore previous buffer */
php_ob_buffer *ob_buffer_p;
@@ -224,10 +228,6 @@ PHPAPI void php_end_ob_buffer(zend_bool send_buffer, zend_bool just_flush)
OG(active_ob_buffer).status |= PHP_OUTPUT_HANDLER_START;
OG(php_body_write) = php_b_body_write;
}
- if (OG(active_ob_buffer).internal_output_handler
- && (internal_output_handler_buffer != OG(active_ob_buffer).internal_output_handler_buffer)) {
- efree(internal_output_handler_buffer);
- }
}