all repos — tint2 @ faa04ee402fc0daf69cb6a7ae83f7e9208343b06

fork of the tint2 desktop panel for my custom setup - only minimized windows across all desktops for the taskbar

fixed theme detection in local .icons directory

git-svn-id: http://tint2.googlecode.com/svn/trunk@580 121b4492-b84c-0410-8b4c-0d4edfb3f3cc
thilor77 thilor77@121b4492-b84c-0410-8b4c-0d4edfb3f3cc
commit

faa04ee402fc0daf69cb6a7ae83f7e9208343b06

parent

eb07f935feb5a1fbe2b31c2960da60633940478c

1 files changed, 15 insertions(+), 10 deletions(-)

jump to
M src/launcher/launcher.csrc/launcher/launcher.c

@@ -473,29 +473,33 @@

if (name == NULL) return NULL; - fprintf(stderr, "Loading icon theme %s\n", name); - - file_name = malloc(100 + strlen(name)); - sprintf(file_name, "~/.icons/%s/index.theme", name); + file_name = g_build_filename(g_get_home_dir(), ".icons", name, "index.theme", NULL); if (!g_file_test(file_name, G_FILE_TEST_EXISTS)) { - sprintf(file_name, "/usr/share/icons/%s/index.theme", name); + g_free (file_name); + file_name = g_build_filename("/usr", "share", "icons", name, "index.theme", NULL); if (!g_file_test(file_name, G_FILE_TEST_EXISTS)) { - sprintf(file_name, "/usr/share/pixmaps/%s/index.theme", name); + g_free (file_name); + file_name = g_build_filename("/usr", "share", "pixmaps", name, "index.theme", NULL); if (!g_file_test(file_name, G_FILE_TEST_EXISTS)) { - free(file_name); + g_free (file_name); file_name = NULL; } } } + if (!file_name) { - fprintf(stderr, "Could not load theme %s\n", name); + fprintf(stderr, "Could not found theme '%s'\n", name); return NULL; } - if ((f = fopen(file_name, "rt")) == NULL) + if ((f = fopen(file_name, "rt")) == NULL) { + fprintf(stderr, "Could not open theme '%s'\n", file_name); return NULL; + } + else + fprintf(stderr, "Loading icon theme '%s'\n", file_name); - free(file_name); + g_free (file_name); theme = calloc(1, sizeof(IconTheme)); theme->name = strdup(name);

@@ -793,6 +797,7 @@ GSList *theme;

for (theme = launcher->icon_themes; theme; theme = g_slist_next(theme)) { GSList *dir; for (dir = ((IconTheme*)theme->data)->list_directories; dir; dir = g_slist_next(dir)) { + //printf("directory %s, size %d\n", ((IconThemeDir*)dir->data)->name, ((IconThemeDir*)dir->data)->size); if (directory_matches_size((IconThemeDir*)dir->data, size)) { GSList *base; for (base = basenames; base; base = g_slist_next(base)) {