From: Hartmut Holzgraefe Date: Tue, 23 May 2000 05:04:28 +0000 (+0000) Subject: again (due to feature request in bug id #3251) X-Git-Tag: PRE_EIGHT_BYTE_ALLOC_PATCH~336 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=78cec9f33ef75a357c2a020cb85b425bbf39566b;p=php again (due to feature request in bug id #3251) added optional 3rd parameter 'limit' to explode() as in split() --- diff --git a/ext/standard/php_string.h b/ext/standard/php_string.h index 9e31cb3cd9..e71cf8f997 100644 --- a/ext/standard/php_string.h +++ b/ext/standard/php_string.h @@ -109,7 +109,7 @@ PHPAPI void php_strip_tags(char *rbuf, int len, int state, char *allow, int allo PHPAPI void php_char_to_str(char *str, uint len, char from, char *to, int to_len, pval *result); PHPAPI void php_implode(pval *delim, pval *arr, pval *return_value); -PHPAPI void php_explode(pval *delim, pval *str, pval *return_value); +PHPAPI void php_explode(pval *delim, pval *str, pval *return_value, int limit); PHPAPI inline char *php_memnstr(char *haystack, char *needle, int needle_len, char *end); PHPAPI size_t php_strspn(char *s1, char *s2, char *s1_end, char *s2_end); PHPAPI size_t php_strcspn(char *s1, char *s2, char *s1_end, char *s2_end); diff --git a/ext/standard/string.c b/ext/standard/string.c index b9c2194c76..4b2cf4dbe5 100644 --- a/ext/standard/string.c +++ b/ext/standard/string.c @@ -213,7 +213,7 @@ PHP_FUNCTION(ltrim) } /* }}} */ -PHPAPI void php_explode(zval *delim, zval *str, zval *return_value) +PHPAPI void php_explode(zval *delim, zval *str, zval *return_value, int limit) { char *p1, *p2, *endp; int i = 0; @@ -229,22 +229,37 @@ PHPAPI void php_explode(zval *delim, zval *str, zval *return_value) do { add_index_stringl(return_value, i++, p1, p2-p1, 1); p1 = p2 + delim->value.str.len; + if((limit>=0)&&(i>=limit-1)) + break; } while ((p2 = php_memnstr(p1, delim->value.str.val, delim->value.str.len, endp)) != NULL); - if (p1 <= endp) { + if ((p1 <= endp)|| ((limit>=0)&&(i>=limit-1))){ add_index_stringl(return_value, i++, p1, endp-p1, 1); } } } -/* {{{ proto array explode(string separator, string str) +/* {{{ proto array explode(string separator, string str [, int limit]) Split a string on string separator and return array of components */ PHP_FUNCTION(explode) { - zval **str, **delim; + zval **str, **delim, **zlimit = NULL; + int limit; - if (ARG_COUNT(ht) != 2 || zend_get_parameters_ex(2, &delim, &str) == FAILURE) { + switch (ARG_COUNT(ht)) { + case 2: + if (zend_get_parameters_ex(2, &delim, &str) == FAILURE) + WRONG_PARAM_COUNT; + limit=-1; + break; + case 3: + if (zend_get_parameters_ex(3, &delim, &str, &zlimit) == FAILURE) WRONG_PARAM_COUNT; + convert_to_long_ex(zlimit); + limit = (*zlimit)->value.lval; + break; + default: + WRONG_PARAM_COUNT; } convert_to_string_ex(str); @@ -259,7 +274,11 @@ PHP_FUNCTION(explode) RETURN_FALSE; } - php_explode(*delim, *str, return_value); + if((limit==0)||(limit==1)) { + add_index_stringl(return_value, 0, (*str)->value.str.val, (*str)->value.str.len, 1); + } else { + php_explode(*delim, *str, return_value, limit); + } } /* }}} */