summaryrefslogtreecommitdiff
path: root/ext/mbstring/mbstring.c
diff options
context:
space:
mode:
Diffstat (limited to 'ext/mbstring/mbstring.c')
-rw-r--r--ext/mbstring/mbstring.c11
1 files changed, 5 insertions, 6 deletions
diff --git a/ext/mbstring/mbstring.c b/ext/mbstring/mbstring.c
index ae8c4bef7f..0e255e98d2 100644
--- a/ext/mbstring/mbstring.c
+++ b/ext/mbstring/mbstring.c
@@ -5010,11 +5010,9 @@ PHP_FUNCTION(mb_chr)
/* }}} */
-static inline char* php_mb_scrub(const char* str, size_t str_len, const mbfl_encoding *enc)
+static inline char* php_mb_scrub(const char* str, size_t str_len, const mbfl_encoding *enc, size_t *ret_len)
{
- size_t ret_len;
-
- return php_mb_convert_encoding_ex(str, str_len, enc, enc, &ret_len);
+ return php_mb_convert_encoding_ex(str, str_len, enc, enc, ret_len);
}
@@ -5027,6 +5025,7 @@ PHP_FUNCTION(mb_scrub)
char *enc_name = NULL;
size_t enc_name_len;
char *ret;
+ size_t ret_len;
ZEND_PARSE_PARAMETERS_START(1, 2)
Z_PARAM_STRING(str, str_len)
@@ -5039,13 +5038,13 @@ PHP_FUNCTION(mb_scrub)
RETURN_FALSE;
}
- ret = php_mb_scrub(str, str_len, enc);
+ ret = php_mb_scrub(str, str_len, enc, &ret_len);
if (ret == NULL) {
RETURN_FALSE;
}
- RETVAL_STRING(ret);
+ RETVAL_STRINGL(ret, ret_len);
efree(ret);
}
/* }}} */