From: Sterling Hughes Date: Sun, 10 Sep 2000 05:59:16 +0000 (+0000) Subject: @- Added the pathinfo() function. (Sterling) X-Git-Tag: php-4.0.3RC1~211 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=0b9a78cb1e3656de3ce5ffbf591528fd7e34d5ee;p=php @- Added the pathinfo() function. (Sterling) --- diff --git a/ext/standard/basic_functions.c b/ext/standard/basic_functions.c index 1251b46acf..7e50c73e9e 100644 --- a/ext/standard/basic_functions.c +++ b/ext/standard/basic_functions.c @@ -152,6 +152,7 @@ function_entry basic_functions[] = { PHP_FE(nl2br, NULL) PHP_FE(basename, NULL) PHP_FE(dirname, NULL) + PHP_FE(pathinfo, NULL) PHP_FE(stripslashes, NULL) PHP_FE(stripcslashes, NULL) PHP_FE(strstr, NULL) diff --git a/ext/standard/php_string.h b/ext/standard/php_string.h index 2021021907..6f247e0df2 100644 --- a/ext/standard/php_string.h +++ b/ext/standard/php_string.h @@ -42,6 +42,7 @@ PHP_FUNCTION(strtoupper); PHP_FUNCTION(strtolower); PHP_FUNCTION(basename); PHP_FUNCTION(dirname); +PHP_FUNCTION(pathinfo); PHP_FUNCTION(strstr); PHP_FUNCTION(strpos); PHP_FUNCTION(strrpos); diff --git a/ext/standard/string.c b/ext/standard/string.c index d95c96b900..fc61aa16b2 100644 --- a/ext/standard/string.c +++ b/ext/standard/string.c @@ -39,12 +39,18 @@ #define STR_PAD_LEFT 0 #define STR_PAD_RIGHT 1 #define STR_PAD_BOTH 2 +#define PHP_PATHINFO_BASENAME 0 +#define PHP_PATHINFO_DIRNAME 1 +#define PHP_PATHINFO_EXTENSION 2 void register_string_constants(INIT_FUNC_ARGS) { - REGISTER_LONG_CONSTANT("STR_PAD_LEFT", STR_PAD_LEFT, CONST_PERSISTENT|CONST_CS); - REGISTER_LONG_CONSTANT("STR_PAD_RIGHT", STR_PAD_RIGHT, CONST_PERSISTENT|CONST_CS); - REGISTER_LONG_CONSTANT("STR_PAD_BOTH", STR_PAD_BOTH, CONST_PERSISTENT|CONST_CS); + REGISTER_LONG_CONSTANT("STR_PAD_LEFT", STR_PAD_LEFT, CONST_CS | CONST_PERSISTENT); + REGISTER_LONG_CONSTANT("STR_PAD_RIGHT", STR_PAD_RIGHT, CONST_CS | CONST_PERSISTENT); + REGISTER_LONG_CONSTANT("STR_PAD_BOTH", STR_PAD_BOTH, CONST_CS | CONST_PERSISTENT); + REGISTER_LONG_CONSTANT("PATHINFO_BASENAME", PHP_PATHINFO_BASENAME, CONST_CS | CONST_PERSISTENT); + REGISTER_LONG_CONSTANT("PATHINFO_DIRNAME", PHP_PATHINFO_DIRNAME, CONST_CS | CONST_PERSISTENT); + REGISTER_LONG_CONSTANT("PATHINFO_EXTENSION", PHP_PATHINFO_EXTENSION, CONST_CS | CONST_PERSISTENT); } int php_tag_find(char *tag, int len, char *set); @@ -702,7 +708,7 @@ PHP_FUNCTION(dirname) zval **str; char *ret; - if (ZEND_NUM_ARGS() != 1 || zend_get_parameters_ex(1, &str)) { + if (ZEND_NUM_ARGS() != 1 || zend_get_parameters_ex(1, &str) == FAILURE) { WRONG_PARAM_COUNT; } convert_to_string_ex(str); @@ -717,6 +723,67 @@ PHP_FUNCTION(dirname) } /* }}} */ +/* {{{ proto array pathinfo(string path) + Return information about a certain string */ +PHP_FUNCTION(pathinfo) +{ + zval **str, **uopt, *tmp; + char *ret; + int argc = ZEND_NUM_ARGS(), opt, len; + + if (argc < 1 || argc > 2 || + zend_get_parameters_ex(argc, &str, &uopt) == FAILURE) { + WRONG_PARAM_COUNT; + } + convert_to_string_ex(str); + len = Z_STRLEN_PP(str); + + if (argc > 1) { + convert_to_long_ex(uopt); + opt = Z_LVAL_PP(uopt); + } + + MAKE_STD_ZVAL(tmp); + array_init(tmp); + + if (opt == PHP_PATHINFO_BASENAME || argc < 2) { + ret = estrndup(Z_STRVAL_PP(str), len); + php_dirname(ret, len); + if (*ret) + add_assoc_string(tmp, "basename", ret, 1); + efree(ret); + } + + if (opt == PHP_PATHINFO_EXTENSION || argc < 2) { + char *p; + int idx; + + ret = estrndup(Z_STRVAL_PP(str), len); + p = strrchr(ret, '.'); + if (*p) { + idx = p - ret; + add_assoc_stringl(tmp, "extension", ret + idx + 1, len - idx - 1, 1); + } + efree(ret); + } + + if (opt == PHP_PATHINFO_DIRNAME || argc < 2) { + ret = php_basename(Z_STRVAL_PP(str), len); + add_assoc_string(tmp, "dirname", ret, 1); + } + + if (zend_hash_num_elements(Z_ARRVAL_P(tmp)) == 1) { + zval **element; + zend_hash_get_current_data(Z_ARRVAL_P(tmp), (void **)&element); + *return_value = **element; + } else { + array_init(return_value); + *return_value = *tmp; + } + + zval_copy_ctor(return_value); +} +/* }}} */ /* case insensitve strstr */ PHPAPI char *php_stristr(unsigned char *s, unsigned char *t,