summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSebastian Dransfeld <sd@tango.flipp.net>2014-08-14 13:29:24 +0200
committerSebastian Dransfeld <sd@tango.flipp.net>2014-08-14 13:30:48 +0200
commite7198621c585af10e03a467befd05a3eaf5b5e51 (patch)
treee465433ae54956d5fe9812a878413d04deecdda9
parentb9c2a081059dfe8e73e83e6da1d938e0a2a715fb (diff)
downloadefl-e7198621c585af10e03a467befd05a3eaf5b5e51.tar.gz
efreet: use eina_file_mkstemp to create filename
-rw-r--r--src/lib/efreet/efreet_desktop_command.c21
1 files changed, 13 insertions, 8 deletions
diff --git a/src/lib/efreet/efreet_desktop_command.c b/src/lib/efreet/efreet_desktop_command.c
index 1e4c51d740..bed40dc7c2 100644
--- a/src/lib/efreet/efreet_desktop_command.c
+++ b/src/lib/efreet/efreet_desktop_command.c
@@ -74,8 +74,6 @@ struct Efreet_Desktop_Command_File
int pending;
};
-static int efreet_desktop_command_file_id = 0;
-
static void *efreet_desktop_exec_cb(void *data, Efreet_Desktop *desktop,
char *exec, int remaining);
static int efreet_desktop_command_flags_get(Efreet_Desktop *desktop);
@@ -647,14 +645,21 @@ efreet_desktop_command_file_process(Efreet_Desktop_Command *command, const char
if (command->flags & EFREET_DESKTOP_EXEC_FLAG_FULLPATH)
{
char buf[PATH_MAX];
+ Eina_Tmpstr *dest;
+ int fd;
- snprintf(buf, sizeof(buf), "/tmp/%d-%d-%s", getpid(),
- efreet_desktop_command_file_id++, base);
- f->fullpath = strdup(buf);
- f->pending = 1;
+ snprintf(buf, sizeof(buf), "%s_XXXXXX", base);
+ fd = eina_file_mkstemp(buf, &dest);
+ if (fd >= 0)
+ {
+ close(fd);
+ f->fullpath = strdup(dest);
+ f->pending = 1;
+ eina_tmpstr_del(dest);
- ecore_file_download(uri, f->fullpath, efreet_desktop_cb_download_complete,
- efreet_desktop_cb_download_progress, f, NULL);
+ ecore_file_download(uri, f->fullpath, efreet_desktop_cb_download_complete,
+ efreet_desktop_cb_download_progress, f, NULL);
+ }
}
if (command->flags & EFREET_DESKTOP_EXEC_FLAG_URI)