diff options
| author | Felipe Pena <felipe@php.net> | 2011-11-21 19:15:18 +0000 | 
|---|---|---|
| committer | Felipe Pena <felipe@php.net> | 2011-11-21 19:15:18 +0000 | 
| commit | 18768584e2b236b7fe798449695c2c0363c947d9 (patch) | |
| tree | bb3b969bbcdfc227685022fe766d35e4649f2b5e /ext/mbstring/php_mbregex.c | |
| parent | 3781026cb832e663871e0cbb8a4154f4f6551600 (diff) | |
| download | php-git-18768584e2b236b7fe798449695c2c0363c947d9.tar.gz | |
- Fixed possible crash in mb_ereg_search_init() using empty pattern
Diffstat (limited to 'ext/mbstring/php_mbregex.c')
| -rw-r--r-- | ext/mbstring/php_mbregex.c | 9 | 
1 files changed, 7 insertions, 2 deletions
| diff --git a/ext/mbstring/php_mbregex.c b/ext/mbstring/php_mbregex.c index f3fd96a556..9bc87a59bd 100644 --- a/ext/mbstring/php_mbregex.c +++ b/ext/mbstring/php_mbregex.c @@ -1310,14 +1310,19 @@ PHP_FUNCTION(mb_ereg_search_init)  {  	size_t argc = ZEND_NUM_ARGS();  	zval *arg_str; -	char *arg_pattern, *arg_options; -	int arg_pattern_len, arg_options_len; +	char *arg_pattern = NULL, *arg_options = NULL; +	int arg_pattern_len = 0, arg_options_len = 0;  	OnigSyntaxType *syntax = NULL;  	OnigOptionType option;  	if (zend_parse_parameters(argc TSRMLS_CC, "z|ss", &arg_str, &arg_pattern, &arg_pattern_len, &arg_options, &arg_options_len) == FAILURE) {  		return;  	} +	 +	if (arg_pattern_len == 0) { +		php_error_docref(NULL TSRMLS_CC, E_WARNING, "Empty pattern"); +		RETURN_FALSE; +	}  	option = MBREX(regex_default_options);  	syntax = MBREX(regex_default_syntax); | 
