summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMoriyoshi Koizumi <moriyoshi@php.net>2003-04-12 21:53:46 +0000
committerMoriyoshi Koizumi <moriyoshi@php.net>2003-04-12 21:53:46 +0000
commitfa0ac8a2733f1d993cf47dea9bdf9b15eb7d1dd0 (patch)
treeadc772579b9984dc9855a6cb83ac55d8f5ca6f94
parent9e46bdd0b2310ada129af1a4681eeca5dc35f8f5 (diff)
downloadphp-git-fa0ac8a2733f1d993cf47dea9bdf9b15eb7d1dd0.tar.gz
Made dirname() binary-safe.
-rw-r--r--TODO1
-rw-r--r--ext/standard/string.c25
-rw-r--r--tests/run-test/test007.phptbin1127 -> 1191 bytes
3 files changed, 14 insertions, 12 deletions
diff --git a/TODO b/TODO
index bc5a3c0974..3bb62d7e9b 100644
--- a/TODO
+++ b/TODO
@@ -140,7 +140,6 @@ ext/standard
* NOT binary safe:
strtok()
basename()
- dirname()
ext/wddx
--------
diff --git a/ext/standard/string.c b/ext/standard/string.c
index c329f9e16a..4c7fc82127 100644
--- a/ext/standard/string.c
+++ b/ext/standard/string.c
@@ -1142,7 +1142,7 @@ PHP_FUNCTION(basename)
/* {{{ php_dirname
Returns directory name component of path */
-PHPAPI void php_dirname(char *path, int len)
+PHPAPI size_t php_dirname(char *path, size_t len)
{
register char *end = path + len - 1;
@@ -1150,7 +1150,7 @@ PHPAPI void php_dirname(char *path, int len)
/* Note that on Win32 CWD is per drive (heritage from CP/M).
* This means dirname("c:foo") maps to "c:." or "c:" - which means CWD on C: drive.
*/
- if ((2 <= len) && isalpha(path[0]) && (':' == path[1])) {
+ if ((2 <= len) && isalpha((int)((unsigned char *)path)[0]) && (':' == path[1])) {
/* Skip over the drive spec (if any) so as not to change */
path += 2;
if (2 == len) {
@@ -1158,14 +1158,14 @@ PHPAPI void php_dirname(char *path, int len)
* It would be more consistent to return "c:."
* but that would require making the string *longer*.
*/
- return;
+ return len;
}
}
#endif
- if (len <= 0) {
+ if (len == 0) {
/* Illegal use of this function */
- return;
+ return 0;
}
/* Strip trailing slashes */
@@ -1176,7 +1176,7 @@ PHPAPI void php_dirname(char *path, int len)
/* The path only contained slashes */
path[0] = DEFAULT_SLASH;
path[1] = '\0';
- return;
+ return 1;
}
/* Strip filename */
@@ -1187,7 +1187,7 @@ PHPAPI void php_dirname(char *path, int len)
/* No slash found, therefore return '.' */
path[0] = '.';
path[1] = '\0';
- return;
+ return 1;
}
/* Strip slashes which came before the file name */
@@ -1197,9 +1197,11 @@ PHPAPI void php_dirname(char *path, int len)
if (end < path) {
path[0] = DEFAULT_SLASH;
path[1] = '\0';
- return;
+ return 1;
}
*(end+1) = '\0';
+
+ return (size_t)(end + 1 - path);
}
/* }}} */
@@ -1209,16 +1211,17 @@ PHP_FUNCTION(dirname)
{
zval **str;
char *ret;
-
+ size_t ret_len;
+
if (ZEND_NUM_ARGS() != 1 || zend_get_parameters_ex(1, &str) == FAILURE) {
WRONG_PARAM_COUNT;
}
convert_to_string_ex(str);
ret = estrndup(Z_STRVAL_PP(str), Z_STRLEN_PP(str));
- php_dirname(ret, Z_STRLEN_PP(str));
+ ret_len = php_dirname(ret, Z_STRLEN_PP(str));
- RETURN_STRING(ret, 0);
+ RETURN_STRINGL(ret, ret_len, 0);
}
/* }}} */
diff --git a/tests/run-test/test007.phpt b/tests/run-test/test007.phpt
index 83f5d7a788..f5f934f72e 100644
--- a/tests/run-test/test007.phpt
+++ b/tests/run-test/test007.phpt
Binary files differ