diff options
| author | Felipe Pena <felipe@php.net> | 2008-10-26 13:48:16 +0000 | 
|---|---|---|
| committer | Felipe Pena <felipe@php.net> | 2008-10-26 13:48:16 +0000 | 
| commit | d1eb03eec77c65b484ae0ccebf40ad6df7773cdf (patch) | |
| tree | 13c578240bd02265b1a8999299c745382aa99266 /ext/standard/streamsfuncs.c | |
| parent | 21490362dda6a60d6818b4bf871b3f3ed4c6c4e8 (diff) | |
| download | php-git-d1eb03eec77c65b484ae0ccebf40ad6df7773cdf.tar.gz | |
- MFH: Fixed bug #46388 (stream_notification_callback inside of object destroys object variables)
Diffstat (limited to 'ext/standard/streamsfuncs.c')
| -rw-r--r-- | ext/standard/streamsfuncs.c | 6 | 
1 files changed, 5 insertions, 1 deletions
| diff --git a/ext/standard/streamsfuncs.c b/ext/standard/streamsfuncs.c index 7dade984ac..73a993b4d2 100644 --- a/ext/standard/streamsfuncs.c +++ b/ext/standard/streamsfuncs.c @@ -819,12 +819,13 @@ static void user_space_stream_notifier(php_stream_context *context, int notifyco  		INIT_ZVAL(zvs[i]);  		ps[i] = &zvs[i];  		ptps[i] = &ps[i]; +		MAKE_STD_ZVAL(ps[i]);  	}  	ZVAL_LONG(ps[0], notifycode);  	ZVAL_LONG(ps[1], severity);  	if (xmsg) { -		ZVAL_STRING(ps[2], xmsg, 0); +		ZVAL_STRING(ps[2], xmsg, 1);  	} else {  		ZVAL_NULL(ps[2]);  	} @@ -835,6 +836,9 @@ static void user_space_stream_notifier(php_stream_context *context, int notifyco  	if (FAILURE == call_user_function_ex(EG(function_table), NULL, callback, &retval, 6, ptps, 0, NULL TSRMLS_CC)) {  		php_error_docref(NULL TSRMLS_CC, E_WARNING, "failed to call user notifier");  	} +	for (i = 0; i < 6; i++) { +		zval_ptr_dtor(&ps[i]); +	}  	if (retval) {  		zval_ptr_dtor(&retval);  	} | 
