summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSebastian Dransfeld <sebastian.dransfeld@sintef.no>2013-06-20 13:27:20 +0200
committerSebastian Dransfeld <sebastian.dransfeld@sintef.no>2013-06-20 13:27:20 +0200
commitb1c97a0da41e9bc998b3d9cf5c724c297582068f (patch)
tree34ee230f2cb8190b2b11ad6847ce8abcf4919b35
parent068f1ddc628b8bff0b82a87201c2e753845c4978 (diff)
downloadefl-b1c97a0da41e9bc998b3d9cf5c724c297582068f.tar.gz
efreet: Create a temp XDG_RUNTIME_DIR if not set
Using /tmp as XDG_RUNTIME_DIR is pointless if we want it to be mode 0700
-rw-r--r--src/lib/efreet/efreet_base.c14
1 files changed, 13 insertions, 1 deletions
diff --git a/src/lib/efreet/efreet_base.c b/src/lib/efreet/efreet_base.c
index 22217bafc3..26346e0a65 100644
--- a/src/lib/efreet/efreet_base.c
+++ b/src/lib/efreet/efreet_base.c
@@ -303,7 +303,19 @@ efreet_dirs_init(void)
xdg_config_dirs = efreet_dirs_get("XDG_CONFIG_DIRS", "/etc/xdg");
/* xdg_runtime_dir */
- xdg_runtime_dir = efreet_dir_get("XDG_RUNTIME_DIR", "/tmp");
+ xdg_runtime_dir = getenv("XDG_RUNTIME_DIR");
+ if (!xdg_runtime_dir)
+ {
+ snprintf(buf, sizeof(buf), "/tmp/xdg-XXXXXX");
+ xdg_runtime_dir = mkdtemp(buf);
+ if (!xdg_runtime_dir)
+ {
+ perror("efreet mkdtemp");
+ xdg_runtime_dir = "/tmp";
+ }
+ }
+ xdg_runtime_dir = eina_stringshare_add(xdg_runtime_dir);
+
if (stat(xdg_runtime_dir, &st) == -1)
{
ERR("$XDG_RUNTIME_DIR did not exist, creating '%s' (breaks spec)",