launcher->area._resize = resize_launcher;
launcher->area.resize = 1;
launcher->area.redraw = 1;
- launcher->area.on_screen = 1;
- if (panel_horizontal) {
- // panel horizonal => fixed height and posy
- launcher->area.posy = panel->area.bg->border.width + panel->area.paddingy;
- launcher->area.height = panel->area.height - (2 * launcher->area.posy);
- }
- else {
- // panel vertical => fixed width, height, posy and posx
- launcher->area.posx = panel->area.bg->border.width + panel->area.paddingxlr;
- launcher->area.width = panel->area.width - (2 * panel->area.bg->border.width) - (2 * panel->area.paddingy);
- }
+ // check consistency
+ if (launcher->list_apps == NULL)
+ return;
+
+ launcher->area.on_screen = 1;
+ panel_refresh = 1;
fprintf(stderr, "Loading themes...\n");
launcher_load_themes(launcher);
launcher_enabled = 0;
}
+
int resize_launcher(void *obj)
{
Launcher *launcher = obj;
- Panel *panel = launcher->area.panel;
GSList *l;
int count, icon_size;
int icons_per_column=1, icons_per_row=1, marging=0;
icons_per_row = count / icons_per_column + (count%icons_per_column != 0);
launcher->area.width = (2 * launcher->area.bg->border.width) + (2 * launcher->area.paddingxlr) + (icon_size * icons_per_row) + ((icons_per_row-1) * launcher->area.paddingx);
}
-
-// launcher->area.posx = panel->area.bg->border.width + panel->area.paddingxlr;
- launcher->area.posy = panel->area.bg->border.width;
}
else {
if (!count) launcher->area.height = 0;
icons_per_column = count / icons_per_row+ (count%icons_per_row != 0);
launcher->area.height = (2 * launcher->area.bg->border.width) + (2 * launcher->area.paddingxlr) + (icon_size * icons_per_column) + ((icons_per_column-1) * launcher->area.paddingx);
}
-
- launcher->area.posx = panel->area.bg->border.width;
-// launcher->area.posy = panel->area.height - panel->area.bg->border.width - panel->area.paddingxlr - launcher->area.height;
}
int i, posx, posy;
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);
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)) {