let the pool cleanup function only become effective, when an
error has occured.
This fixes the problem that the request_conn was already dead
when the request_shutdown was reached.
SLS_FETCH();
APLS_FETCH();
- AP(in_request)=0;
SG(server_context) = NULL; /* The server context (request) is invalid by the time run_cleanups() is called */
- php_request_shutdown(dummy);
+ if (AP(in_request)) {
+ AP(in_request) = 0;
+ php_request_shutdown(dummy);
+ }
}
/* }}} */
#include "ext/standard/php_standard.h"
#include "util_script.h"
#include "php_version.h"
-/*#include "mod_php4.h"*/
+#include "mod_php4.h"
/* {{{ apache_php_module_main
*/
int apache_php_module_main(request_rec *r, int display_source_mode CLS_DC ELS_DC PLS_DC SLS_DC)
{
zend_file_handle file_handle;
+ APLS_FETCH();
if (php_request_startup(CLS_C ELS_CC PLS_CC SLS_CC) == FAILURE) {
return FAILURE;
(void) php_execute_script(&file_handle CLS_CC ELS_CC PLS_CC);
}
+ AP(in_request) = 0;
+
zend_try {
- php_end_ob_buffers(1);
- php_header(); /* Make sure headers have been sent */
+ php_request_shutdown(NULL);
} zend_end_try();
+
return (OK);
}
/* }}} */