summaryrefslogtreecommitdiff
path: root/ext
diff options
context:
space:
mode:
authorMoriyoshi Koizumi <moriyoshi@php.net>2003-04-03 00:15:13 +0000
committerMoriyoshi Koizumi <moriyoshi@php.net>2003-04-03 00:15:13 +0000
commit8784a497b891153b0032d1446d5ad22e80a72f1d (patch)
tree9a24323f285a992ebf619b2f9a952aa9e9287171 /ext
parent8b539ed7661a7ec18b080a3d023813580f63f6ff (diff)
downloadphp-git-8784a497b891153b0032d1446d5ad22e80a72f1d.tar.gz
Fixed segfault in mb_ereg_match()
Diffstat (limited to 'ext')
-rw-r--r--ext/mbstring/php_mbregex.c12
1 files changed, 6 insertions, 6 deletions
diff --git a/ext/mbstring/php_mbregex.c b/ext/mbstring/php_mbregex.c
index 6227a91634..27aef6cef1 100644
--- a/ext/mbstring/php_mbregex.c
+++ b/ext/mbstring/php_mbregex.c
@@ -782,7 +782,8 @@ PHP_FUNCTION(mb_split)
Regular expression match for multibyte string */
PHP_FUNCTION(mb_ereg_match)
{
- zval *arg_pattern;
+ char *arg_pattern;
+ int arg_pattern_len;
char *string;
int string_len;
@@ -795,8 +796,8 @@ PHP_FUNCTION(mb_ereg_match)
char *option_str = NULL;
int option_str_len = 0;
- if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "zs|s",
- &arg_pattern, &string, &string_len,
+ if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "ss|s",
+ &arg_pattern, &arg_pattern_len, &string, &string_len,
&option_str, &option_str_len)==FAILURE) {
RETURN_FALSE;
}
@@ -807,12 +808,11 @@ PHP_FUNCTION(mb_ereg_match)
option |= MBSTRG(regex_default_options);
}
}
- convert_to_string_ex(&arg_pattern);
err = php_mbregex_compile_pattern(
&re,
- Z_STRVAL_P(arg_pattern),
- Z_STRLEN_P(arg_pattern),
+ arg_pattern,
+ arg_pattern_len,
option, MBSTRG(current_mbctype) TSRMLS_CC);
if (err) {