tony2001 Fri Aug 10 10:13:07 2007 UTC
Modified files:
/php-src/main php_open_temporary_file.c
Log:
resolve dir before calling mktemp/mkstemp
this is tested by ext/standard/tests/file/tempnam_variation2.phpt
http://cvs.php.net/viewvc.cgi/php-src/main/php_open_temporary_file.c?r1=1.43&r2=1.44&diff_format=u
Index: php-src/main/php_open_temporary_file.c
diff -u php-src/main/php_open_temporary_file.c:1.43
php-src/main/php_open_temporary_file.c:1.44
--- php-src/main/php_open_temporary_file.c:1.43 Sat Jul 21 01:41:55 2007
+++ php-src/main/php_open_temporary_file.c Fri Aug 10 10:13:07 2007
@@ -16,7 +16,7 @@
+----------------------------------------------------------------------+
*/
-/* $Id: php_open_temporary_file.c,v 1.43 2007/07/21 01:41:55 jani Exp $ */
+/* $Id: php_open_temporary_file.c,v 1.44 2007/08/10 10:13:07 tony2001 Exp $ */
#include "php.h"
@@ -98,7 +98,8 @@
{
char *trailing_slash;
char *opened_path;
- int path_len = 0;
+ char cwd[MAXPATHLEN];
+ cwd_state new_state;
int fd = -1;
#ifndef HAVE_MKSTEMP
int open_flags = O_CREAT | O_TRUNC | O_RDWR
@@ -108,25 +109,36 @@
;
#endif
- if (!path) {
+ if (!path || !path[0]) {
return -1;
}
- path_len = strlen(path);
+ if (!VCWD_GETCWD(cwd, MAXPATHLEN)) {
+ cwd[0] = '\0';
+ }
+
+ new_state.cwd = strdup(cwd);
+ new_state.cwd_length = strlen(cwd);
+
+ if (virtual_file_ex(&new_state, path, NULL, CWD_REALPATH)) {
+ free(new_state.cwd);
+ return -1;
+ }
- if (!path_len || IS_SLASH(path[path_len - 1])) {
+ if (IS_SLASH(new_state.cwd[new_state.cwd_length - 1])) {
trailing_slash = "";
} else {
trailing_slash = "/";
}
- if (spprintf(&opened_path, 0, "%s%s%sXXXXXX", path, trailing_slash,
pfx) >= MAXPATHLEN) {
+ if (spprintf(&opened_path, 0, "%s%s%sXXXXXX", new_state.cwd,
trailing_slash, pfx) >= MAXPATHLEN) {
efree(opened_path);
+ free(new_state.cwd);
return -1;
}
#ifdef PHP_WIN32
- if (GetTempFileName(path, pfx, 0, opened_path)) {
+ if (GetTempFileName(new_state.cwd, pfx, 0, opened_path)) {
/* Some versions of windows set the temp file to be read-only,
* which means that opening it will fail... */
VCWD_CHMOD(opened_path, 0600);
@@ -144,6 +156,7 @@
} else {
*opened_path_p = opened_path;
}
+ free(new_state.cwd);
return fd;
}
/* }}} */
--
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php