From: Gustavo André dos Santos Lopes Date: Tue, 5 Jul 2011 16:09:06 +0000 (+0000) Subject: - Fixed bug #52935 (call exit in user_error_handler cause stream relate core). X-Git-Tag: php-5.4.0alpha2~51 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=afe4570cda15b5faa440376433a4dd93077679d1;p=php - Fixed bug #52935 (call exit in user_error_handler cause stream relate core). --- diff --git a/main/streams/streams.c b/main/streams/streams.c index 673795971a..15c1454547 100755 --- a/main/streams/streams.c +++ b/main/streams/streams.c @@ -163,6 +163,7 @@ void php_stream_display_wrapper_errors(php_stream_wrapper *wrapper, const char * char *tmp = estrdup(path); char *msg; int free_msg = 0; + php_stream_wrapper orig_wrapper; if (wrapper) { if (wrapper->err_count > 0) { @@ -207,7 +208,16 @@ void php_stream_display_wrapper_errors(php_stream_wrapper *wrapper, const char * } php_strip_url_passwd(tmp); + if (wrapper) { + /* see bug #52935 */ + orig_wrapper = *wrapper; + wrapper->err_stack = NULL; + wrapper->err_count = 0; + } php_error_docref1(NULL TSRMLS_CC, tmp, E_WARNING, "%s: %s", caption, msg); + if (wrapper) { + *wrapper = orig_wrapper; + } efree(tmp); if (free_msg) { efree(msg);