diff options
author | Sebastian Dransfeld <sd@tango.flipp.net> | 2014-08-14 13:29:24 +0200 |
---|---|---|
committer | Sebastian Dransfeld <sd@tango.flipp.net> | 2014-08-14 13:30:48 +0200 |
commit | e7198621c585af10e03a467befd05a3eaf5b5e51 (patch) | |
tree | e465433ae54956d5fe9812a878413d04deecdda9 | |
parent | b9c2a081059dfe8e73e83e6da1d938e0a2a715fb (diff) | |
download | efl-e7198621c585af10e03a467befd05a3eaf5b5e51.tar.gz |
efreet: use eina_file_mkstemp to create filename
-rw-r--r-- | src/lib/efreet/efreet_desktop_command.c | 21 |
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) |