mirror of
https://github.com/php/php-src.git
synced 2025-01-25 05:04:20 +08:00
MFB: main/php_open_temporary_file.c
This commit is contained in:
parent
8767cd2df4
commit
bec31fe85a
@ -206,7 +206,7 @@ PHPAPI const char* php_get_temporary_directory(void)
|
||||
PHPAPI int php_open_temporary_fd(const char *dir, const char *pfx, char **opened_path_p TSRMLS_DC)
|
||||
{
|
||||
int fd;
|
||||
const char *temp_dir = php_get_temporary_directory();
|
||||
const char *temp_dir;
|
||||
|
||||
if (!pfx) {
|
||||
pfx = "tmp.";
|
||||
@ -216,6 +216,9 @@ PHPAPI int php_open_temporary_fd(const char *dir, const char *pfx, char **opened
|
||||
}
|
||||
|
||||
if (!dir || *dir == '\0') {
|
||||
def_tmp:
|
||||
temp_dir = php_get_temporary_directory();
|
||||
|
||||
if (temp_dir && *temp_dir != '\0' && !php_check_open_basedir(temp_dir TSRMLS_CC)) {
|
||||
return php_do_open_temporary_file(temp_dir, pfx, opened_path_p TSRMLS_CC);
|
||||
} else {
|
||||
@ -227,7 +230,7 @@ PHPAPI int php_open_temporary_fd(const char *dir, const char *pfx, char **opened
|
||||
fd = php_do_open_temporary_file(dir, pfx, opened_path_p TSRMLS_CC);
|
||||
if (fd == -1) {
|
||||
/* Use default temporary directory. */
|
||||
fd = php_do_open_temporary_file(temp_dir, pfx, opened_path_p TSRMLS_CC);
|
||||
goto def_tmp;
|
||||
}
|
||||
return fd;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user