X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Ftint2conf%2Fmain.c;h=874c7e6fecc72c1442544b2597f6c89070f0115b;hb=46f53881443c06b9216e78baab429fd45205aa20;hp=e2bbb29829915ab6a8c0d0105b035ad2a6c125b2;hpb=9f561215b52f7e275bbe50faa68cfc9fbc935994;p=chaz%2Ftint2 diff --git a/src/tint2conf/main.c b/src/tint2conf/main.c index e2bbb29..874c7e6 100644 --- a/src/tint2conf/main.c +++ b/src/tint2conf/main.c @@ -35,9 +35,9 @@ // default config file and directory -char *g_path_config = 0; -char *g_path_dir = 0; -char *g_default_theme = 0; +char *g_path_config = NULL; +char *g_path_dir = NULL; +char *g_default_theme = NULL; int g_width; int g_height; @@ -51,13 +51,13 @@ static void menuAddWidget (GtkUIManager *, GtkWidget *, GtkContainer *); // action on menus static void menuAdd (GtkWindow * parent); -//static void menuSaveAs (GtkWindow *parent); +static void menuSaveAs (GtkWindow *parent); static void menuDelete (void); static void menuProperties (void); -static void menuRename (void); static void menuQuit (void); static void menuRefresh (void); static void menuRefreshAll (void); +static void menuPreferences (void); static void menuApply (void); static void menuAbout(GtkWindow * parent); @@ -79,32 +79,31 @@ static const char *global_ui = " " " " " " -// " " + " " " " " " " " " " - " " " " " " " " - " " - " " - " " + " " + " " + " " +// " " +// " " " " " " " " " " " " " " - " " - " " - " " " " + " " " " " " + " " " " - " " " " " " " " @@ -115,14 +114,14 @@ static const char *global_ui = static GtkActionEntry entries[] = { {"ThemeMenu", NULL, "Theme", NULL, NULL, NULL}, {"ThemeAdd", GTK_STOCK_ADD, "_Add...", "N", "Add theme", G_CALLBACK (menuAdd)}, -// {"ThemeSaveAs", GTK_STOCK_SAVE_AS, "_Save as...", NULL, "Save theme as", G_CALLBACK (menuSaveAs)}, + {"ThemeSaveAs", GTK_STOCK_SAVE_AS, "_Save as...", NULL, "Save theme as", G_CALLBACK (menuSaveAs)}, {"ThemeDelete", GTK_STOCK_DELETE, "_Delete", NULL, "Delete theme", G_CALLBACK (menuDelete)}, {"ThemeProperties", GTK_STOCK_PROPERTIES, "_Properties...", NULL, "Show properties", G_CALLBACK (menuProperties)}, - {"ThemeRename", NULL, "_Rename...", NULL, "Rename theme", G_CALLBACK (menuRename)}, {"ThemeQuit", GTK_STOCK_QUIT, "_Quit", "Q", "Quit", G_CALLBACK (menuQuit)}, - {"ViewMenu", NULL, "View", NULL, NULL, NULL}, - {"ViewRefresh", GTK_STOCK_REFRESH, "Refresh", NULL, "Refresh", G_CALLBACK (menuRefresh)}, - {"ViewRefreshAll", GTK_STOCK_REFRESH, "Refresh all", NULL, "Refresh all", G_CALLBACK (menuRefreshAll)}, + {"EditMenu", NULL, "Edit", NULL, NULL, NULL}, + {"EditRefresh", GTK_STOCK_REFRESH, "Refresh", NULL, "Refresh", G_CALLBACK (menuRefresh)}, + {"EditRefreshAll", GTK_STOCK_REFRESH, "Refresh all", NULL, "Refresh all", G_CALLBACK (menuRefreshAll)}, +// {"EditPreferences", GTK_STOCK_PREFERENCES, "Preferences", NULL, "Preferences", G_CALLBACK (menuPreferences)}, {"ViewApply", GTK_STOCK_APPLY, "Apply", NULL, "Apply theme", G_CALLBACK (menuApply)}, {"HelpMenu", NULL, "Help", NULL, NULL, NULL}, {"HelpAbout", GTK_STOCK_ABOUT, "_About", "A", "About", G_CALLBACK (menuAbout)} @@ -161,7 +160,7 @@ int main (int argc, char ** argv) gtk_box_pack_start(GTK_BOX(vBox), scrollbar, TRUE, TRUE, 0); // define theme view - g_theme_view = create_view_and_model(); + g_theme_view = create_view(); gtk_container_add(GTK_CONTAINER(scrollbar), g_theme_view); gtk_widget_show(g_theme_view); g_signal_connect(g_theme_view, "button-press-event", (GCallback)view_onButtonPressed, NULL); @@ -232,16 +231,11 @@ static void menuAdd (GtkWindow *parent) if (pt1) { pt1++; if (*pt1) { - name = strdup(pt1); + name = g_strdup(pt1); path = g_build_filename (g_get_user_config_dir(), "tint2", name, NULL); copy_file(file, path); + add_to_list(g_theme_view, path); g_free(path); - pt1 = strstr(name, ".tint2rc"); - if (pt1) { - file = strndup(name, pt1-name); - add_to_list(g_theme_view, file); - g_free(file); - } g_free(name); } } @@ -253,7 +247,7 @@ static void menuAdd (GtkWindow *parent) gtk_widget_destroy (dialog); } -/* + static void menuSaveAs (GtkWindow *parent) { GtkWidget *dialog; @@ -274,28 +268,23 @@ static void menuSaveAs (GtkWindow *parent) } gtk_widget_destroy (dialog); } -*/ + static void menuDelete (void) { GtkTreeSelection *sel; GtkTreeIter iter; GtkTreeModel *model; - char *value, *name1, *name2; + char *value; sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(g_theme_view)); if (gtk_tree_selection_get_selected(GTK_TREE_SELECTION(sel), &model, &iter)) { gtk_tree_model_get(model, &iter, COL_TEXT, &value, -1); gtk_tree_selection_unselect_all(sel); - // remove from the gui - gtk_list_store_remove(GTK_LIST_STORE(model), &iter); - - name1 = g_build_filename (g_get_user_config_dir(), "tint2", value, NULL); - name2 = g_strdup_printf("%s.tint2rc", name1); - g_remove(name2); - g_free(name1); - g_free(name2); + // remove (gui and disk) + gtk_list_store_remove(GTK_LIST_STORE(model), &iter); + g_remove(value); g_free(value); } } @@ -306,33 +295,21 @@ static void menuProperties (void) GtkTreeSelection *sel; GtkTreeIter iter; GtkTreeModel *model; - char *value, *name1, *name2, *cmd; + char *value, *cmd; sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(g_theme_view)); if (gtk_tree_selection_get_selected(GTK_TREE_SELECTION(sel), &model, &iter)) { gtk_tree_model_get(model, &iter, COL_TEXT, &value, -1); - name1 = g_build_filename ("\'", g_get_user_config_dir(), "tint2", value, NULL); - name2 = g_strdup_printf("%s.tint2rc\'", name1); - - cmd = g_strdup_printf("tintwizard.py %s", name2); + cmd = g_strdup_printf("tintwizard.py \'%s\'", value); system(cmd); - g_free(cmd); - g_free(name1); - g_free(name2); + g_free(cmd); g_free(value); } } -static void menuRename (void) -{ - printf("menuRename\n"); - // g_rename -} - - static void menuQuit (void) { write_config(); @@ -354,24 +331,25 @@ static void menuRefreshAll (void) } +static void menuPreferences (void) +{ + printf("menuPreferences\n"); +} + + static void menuApply (void) { GtkTreeSelection *sel; GtkTreeIter iter; GtkTreeModel *model; - char *value, *name1, *name2; + char *value; sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(g_theme_view)); if (gtk_tree_selection_get_selected(GTK_TREE_SELECTION(sel), &model, &iter)) { gtk_tree_model_get(model, &iter, COL_TEXT, &value, -1); - name1 = g_build_filename (g_get_user_config_dir(), "tint2", value, NULL); - name2 = g_strdup_printf("%s.tint2rc", name1); - g_free(name1); - copy_file(name2, g_path_config); - write_config(); + copy_file(value, g_path_config); g_free(value); - g_free(name2); // restart panel system("killall -SIGUSR1 tint2"); @@ -430,23 +408,34 @@ static void load_theme(GtkWidget *list) { GDir *dir; gchar *file, *pt1, *name; + int found_theme = FALSE; dir = g_dir_open(g_path_dir, 0, NULL); + if (dir == NULL) return; while ((file = g_dir_read_name(dir))) { pt1 = strstr(file, ".tint2rc"); if (pt1) { - name = strndup(file, pt1-file); + found_theme = TRUE; + name = g_build_filename (g_path_dir, file, NULL); add_to_list(list, name); g_free(name); } } g_dir_close(dir); + if (!found_theme) { + // create default theme file + file = g_build_filename (g_get_user_config_dir(), "tint2", "default.tint2rc", NULL); + copy_file(g_path_config, file); + add_to_list(list, file); + g_free(file); + } + // search default theme GtkTreeIter iter; GtkTreeModel *model; - if (g_default_theme) { - printf("defaultTheme %s\n", g_default_theme); + if (g_default_theme != NULL) { + printf("loadTheme : defaultTheme %s\n", g_default_theme); //gtk_tree_selection_select_iter(GtkTreeSelection *selection, GtkTreeIter *iter); } } @@ -457,8 +446,10 @@ void read_config() { char *path; - if (g_default_theme) + if (g_default_theme != NULL) { g_free(g_default_theme); + g_default_theme = NULL; + } g_width = 600; g_height = 350; @@ -484,6 +475,8 @@ void read_config() } } g_free(path); + if (g_default_theme != NULL) + printf("readConfig : defaultTheme %s\n", g_default_theme); } @@ -518,7 +511,10 @@ void write_config() if (fp != NULL) { fputs("#---------------------------------------------\n", fp); fputs("# TINT2CONF CONFIG FILE\n", fp); - fprintf(fp, "default_theme = %s\n", g_default_theme); + if (g_default_theme != NULL) { + fprintf(fp, "default_theme = %s\n", g_default_theme); + printf("default_theme %s\n", g_default_theme); + } fprintf(fp, "width = %d\n", g_width); fprintf(fp, "height = %d\n", g_height); fputs("\n", fp);