From 51a8df9da5d84c0a068a1d37885acd07817ab251 Mon Sep 17 00:00:00 2001 From: Dave Davenport Date: Thu, 24 Aug 2023 19:46:29 +0200 Subject: [PATCH] [Rofi] Expand cache-dir Fixes: #1892 --- source/rofi.c | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/source/rofi.c b/source/rofi.c index b397723b..0b98c461 100644 --- a/source/rofi.c +++ b/source/rofi.c @@ -82,6 +82,7 @@ char *pidfile = NULL; /** Location of Cache directory. */ const char *cache_dir = NULL; +char *cache_dir_alloc = NULL; /** List of error messages.*/ GList *list_of_error_msgs = NULL; @@ -543,6 +544,11 @@ static void cleanup(void) { rofi_theme_free(rofi_configuration); rofi_configuration = NULL; } + // Cleanup memory allocated by rofi_expand_path + if (cache_dir_alloc) { + g_free(cache_dir_alloc); + cache_dir_alloc = NULL; + } } /** @@ -802,10 +808,10 @@ static gboolean startup(G_GNUC_UNUSED gpointer data) { size_t index = 0, i = 0; size_t length = 1024; msg = malloc(length * sizeof(char)); - while ((i = fread(&msg[index], 1, 1024, stdin))>0) { - index+=i; - length+=i; - msg = realloc(msg,length * sizeof(char)); + while ((i = fread(&msg[index], 1, 1024, stdin)) > 0) { + index += i; + length += i; + msg = realloc(msg, length * sizeof(char)); } if (!rofi_view_error_dialog(msg, markup)) { @@ -1087,7 +1093,7 @@ int main(int argc, char *argv[]) { cache_dir = g_get_user_cache_dir(); if (config.cache_dir != NULL) { - cache_dir = config.cache_dir; + cache_dir = cache_dir_alloc = rofi_expand_path(config.cache_dir); } if (g_mkdir_with_parents(cache_dir, 0700) < 0) {