X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=obt%2Fpaths.c;h=6100499893e306a3dce92cd1fd041f49c20c85c2;hb=2c64fe685ec3e2eae70958518e6fc27b2334bc10;hp=c43d48b87e4ae33a9998fd592c222b0c03b65810;hpb=46cf95d36b29cd6bda18ba2d511be10b8e9471cc;p=chaz%2Fopenbox diff --git a/obt/paths.c b/obt/paths.c index c43d48b8..61004998 100644 --- a/obt/paths.c +++ b/obt/paths.c @@ -34,6 +34,7 @@ struct _ObtPaths gint ref; gchar *config_home; gchar *data_home; + gchar *cache_home; GSList *config_dirs; GSList *data_dirs; }; @@ -95,6 +96,12 @@ ObtPaths* obt_paths_new(void) p->data_home = g_build_filename(g_get_home_dir(), ".local", "share", NULL); + path = g_getenv("XDG_CACHE_HOME"); + if (path && path[0] != '\0') /* not unset or empty */ + p->cache_home = g_build_filename(path, NULL); + else + p->cache_home = g_build_filename(g_get_home_dir(), ".cache", NULL); + path = g_getenv("XDG_CONFIG_DIRS"); if (path && path[0] != '\0') /* not unset or empty */ p->config_dirs = split_paths(path); @@ -154,6 +161,7 @@ void obt_paths_unref(ObtPaths *p) g_slist_free(p->data_dirs); g_free(p->config_home); g_free(p->data_home); + g_free(p->cache_home); obt_free0(p, ObtPaths, 1); } @@ -223,6 +231,11 @@ const gchar* obt_paths_data_home(ObtPaths *p) return p->data_home; } +const gchar* obt_paths_cache_home(ObtPaths *p) +{ + return p->cache_home; +} + GSList* obt_paths_config_dirs(ObtPaths *p) { return p->config_dirs;