summaryrefslogtreecommitdiff
path: root/main/php_open_temporary_file.c
diff options
context:
space:
mode:
Diffstat (limited to 'main/php_open_temporary_file.c')
-rw-r--r--main/php_open_temporary_file.c189
1 files changed, 109 insertions, 80 deletions
diff --git a/main/php_open_temporary_file.c b/main/php_open_temporary_file.c
index 258e920a4f..945d2e6019 100644
--- a/main/php_open_temporary_file.c
+++ b/main/php_open_temporary_file.c
@@ -87,60 +87,108 @@
* SUCH DAMAGE.
*/
-static FILE *php_do_open_temporary_file(char *path, const char *pfx, char **opened_path_p TSRMLS_DC)
+static FILE *php_do_open_temporary_file(const char *path, const char *pfx, char **opened_path_p TSRMLS_DC)
{
- char *trailing_slash;
- FILE *fp;
- char *opened_path;
+ char *trailing_slash;
+ FILE *fp;
+ char *opened_path;
#ifndef PHP_WIN32
- int fd;
+ int fd;
#endif
- if (!path) {
- return NULL;
- }
+ if (!path) {
+ return NULL;
+ }
- if (!(opened_path = emalloc(MAXPATHLEN))) {
- return NULL;
- }
+ if (!(opened_path = emalloc(MAXPATHLEN))) {
+ return NULL;
+ }
- if (path[strlen(path)-1] == '/') {
- trailing_slash = "";
- } else {
- trailing_slash = "/";
- }
+ if (path[strlen(path)-1] == '/') {
+ trailing_slash = "";
+ } else {
+ trailing_slash = "/";
+ }
- (void)snprintf(opened_path, MAXPATHLEN, "%s%s%sXXXXXX", path, trailing_slash, pfx);
+ (void)snprintf(opened_path, MAXPATHLEN, "%s%s%sXXXXXX", path, trailing_slash, pfx);
#ifdef PHP_WIN32
- if (GetTempFileName(path, pfx, 0, opened_path)) {
- fp = VCWD_FOPEN(opened_path, "wb");
- } else {
- fp = NULL;
- }
+ if (GetTempFileName(path, pfx, 0, opened_path)) {
+ fp = VCWD_FOPEN(opened_path, "wb");
+ } else {
+ fp = NULL;
+ }
#elif defined(HAVE_MKSTEMP)
- fd = mkstemp(opened_path);
- if (fd==-1) {
- fp = NULL;
- } else {
- fp = fdopen(fd, "wb");
- }
+ fd = mkstemp(opened_path);
+ if (fd==-1) {
+ fp = NULL;
+ } else {
+ fp = fdopen(fd, "wb");
+ }
#else
- if (mktemp(opened_path)) {
- fp = VCWD_FOPEN(opened_path, "wb");
- } else {
- fp = NULL;
- }
+ if (mktemp(opened_path)) {
+ fp = VCWD_FOPEN(opened_path, "wb");
+ } else {
+ fp = NULL;
+ }
#endif
- if (!fp || !opened_path_p) {
- efree(opened_path);
- } else {
- *opened_path_p = opened_path;
- }
- return fp;
+ if (!fp || !opened_path_p) {
+ efree(opened_path);
+ } else {
+ *opened_path_p = opened_path;
+ }
+ return fp;
}
/* }}} */
+/*
+ * Determine where to place temporary files.
+ */
+const char* get_temporary_directory()
+{
+ /* Cache the chosen temporary directory. */
+ static char* temporary_directory;
+
+ /* Did we determine the temporary directory already? */
+ if (temporary_directory) {
+ return temporary_directory;
+ }
+
+#ifdef PHP_WIN32
+ /* We can't count on the environment variables TEMP or TMP,
+ * and so must make the Win32 API call to get the default
+ * directory for temporary files. Note this call checks
+ * the environment values TMP and TEMP (in order) first.
+ */
+ {
+ char sTemp[MAX_PATH];
+ DWORD n = GetTempPath(sizeof(sTemp),sTemp);
+ assert(0 < n); /* should *never* fail! */
+ temporary_directory = strdup(sTemp);
+ return temporary_directory;
+ }
+#else
+ /* On Unix use the (usual) TMPDIR environment variable. */
+ {
+ char* s = getenv("TMPDIR");
+ if (s) {
+ temporary_directory = strdup(s);
+ return temporary_directory;
+ }
+ }
+#ifdef P_tmpdir
+ /* Use the standard default temporary directory. */
+ if (P_tmpdir) {
+ temporary_directory = P_tmpdir;
+ return temporary_directory;
+ }
+#endif
+ /* Shouldn't ever(!) end up here ... last ditch default. */
+ temporary_directory = "/tmp";
+ return temporary_directory;
+#endif
+}
+
/* {{{ php_open_temporary_file
*
* Unlike tempnam(), the supplied dir argument takes precedence
@@ -150,47 +198,28 @@ static FILE *php_do_open_temporary_file(char *path, const char *pfx, char **open
*/
PHPAPI FILE *php_open_temporary_file(const char *dir, const char *pfx, char **opened_path_p TSRMLS_DC)
{
- static char path_tmp[] = "/tmp";
- FILE *fp;
-
-
- if (!pfx) {
- pfx = "tmp.";
- }
-
- if (opened_path_p) {
- *opened_path_p = NULL;
- }
-
- if ((fp=php_do_open_temporary_file((char *) dir, pfx, opened_path_p TSRMLS_CC))) {
- return fp;
- }
-
- if ((fp=php_do_open_temporary_file(getenv("TMPDIR"), pfx, opened_path_p TSRMLS_CC))) {
- return fp;
- }
-#if PHP_WIN32
- {
- char *TempPath;
-
- TempPath = (char *) emalloc(MAXPATHLEN);
- if (GetTempPath(MAXPATHLEN, TempPath)) {
- fp = php_do_open_temporary_file(TempPath, pfx, opened_path_p TSRMLS_CC);
- }
- efree(TempPath);
- return fp;
- }
-#else
- if ((fp=php_do_open_temporary_file(P_tmpdir, pfx, opened_path_p TSRMLS_CC))) {
- return fp;
- }
-
- if ((fp=php_do_open_temporary_file(path_tmp, pfx, opened_path_p TSRMLS_CC))) {
- return fp;
- }
-#endif
-
- return NULL;
+ FILE* fp = 0;
+
+ if (!pfx) {
+ pfx = "tmp.";
+ }
+ if (opened_path_p) {
+ *opened_path_p = NULL;
+ }
+
+ /* Try the directory given as parameter. */
+ fp = php_do_open_temporary_file(dir, pfx, opened_path_p TSRMLS_CC);
+ if (fp) {
+ return fp;
+ }
+
+ /* Use default temporary directory. */
+ fp = php_do_open_temporary_file(get_temporary_directory(), pfx, opened_path_p TSRMLS_CC);
+ if (fp) {
+ return fp;
+ }
+
+ return 0;
}
/* }}} */