diff options
| author | Felipe Pena <felipe@php.net> | 2010-06-11 23:20:13 +0000 | 
|---|---|---|
| committer | Felipe Pena <felipe@php.net> | 2010-06-11 23:20:13 +0000 | 
| commit | 5eb64a49576a0768dcffce52f92af7207f300d04 (patch) | |
| tree | 977fa521bf5af4b69d2fca437f2557d6704c36f5 /Zend/zend_builtin_functions.c | |
| parent | 899bc2f5820955641d8829b4957dde7b197244da (diff) | |
| download | php-git-5eb64a49576a0768dcffce52f92af7207f300d04.tar.gz | |
- Fixed bug #52060 (Memory leak when passing a closure to method_exists())
Diffstat (limited to 'Zend/zend_builtin_functions.c')
| -rw-r--r-- | Zend/zend_builtin_functions.c | 14 | 
1 files changed, 11 insertions, 3 deletions
| diff --git a/Zend/zend_builtin_functions.c b/Zend/zend_builtin_functions.c index a56a823f7c..06833ba97e 100644 --- a/Zend/zend_builtin_functions.c +++ b/Zend/zend_builtin_functions.c @@ -26,6 +26,7 @@  #include "zend_ini.h"  #include "zend_exceptions.h"  #include "zend_extensions.h" +#include "zend_closures.h"  #undef ZEND_TEST_EXCEPTIONS @@ -1098,22 +1099,29 @@ ZEND_FUNCTION(method_exists)  		RETURN_TRUE;  	} else {  		union _zend_function *func = NULL; -		efree(lcname);  		if (Z_TYPE_P(klass) == IS_OBJECT   		&& Z_OBJ_HT_P(klass)->get_method != NULL  		&& (func = Z_OBJ_HT_P(klass)->get_method(&klass, method_name, method_len TSRMLS_CC)) != NULL  		) {  			if (func->type == ZEND_INTERNAL_FUNCTION  -			&& ((zend_internal_function*)func)->handler == zend_std_call_user_call +			&& (func->common.fn_flags & ZEND_ACC_CALL_VIA_HANDLER) != 0  			) { +				/* Returns true to the fake Closure's __invoke */ +				RETVAL_BOOL((func->common.scope == zend_ce_closure +					&& (method_len == sizeof(ZEND_INVOKE_FUNC_NAME)-1) +					&& memcmp(lcname, ZEND_INVOKE_FUNC_NAME, sizeof(ZEND_INVOKE_FUNC_NAME)-1) == 0) ? 1 : 0); + +				efree(lcname);  				efree(((zend_internal_function*)func)->function_name);  				efree(func); -				RETURN_FALSE; +				return;  			} +			efree(lcname);  			RETURN_TRUE;  		}  	} +	efree(lcname);  	RETURN_FALSE;  }  /* }}} */ | 
