X-Git-Url: https://git.brokenzipper.com/gitweb?a=blobdiff_plain;ds=sidebyside;f=src%2Ftint2conf%2Fmain.c;h=bb6f509f6322fae12816ce1afe132d4eee953b83;hb=a5e1fb6d51a4eac007571b88f0421022e21c3500;hp=e8c385b1ac0d0bc2c67e276c72cb9531f96291b3;hpb=e92c129cb3795408bcb0a305e4d52c03e39af56b;p=chaz%2Ftint2 diff --git a/src/tint2conf/main.c b/src/tint2conf/main.c index e8c385b..bb6f509 100644 --- a/src/tint2conf/main.c +++ b/src/tint2conf/main.c @@ -32,6 +32,7 @@ #include "common.h" #include "theme_view.h" +#define SNAPSHOT_TICK 190 // default config file and directory @@ -39,48 +40,37 @@ char *g_path_config = NULL; char *g_path_dir = NULL; char *g_default_theme = NULL; int g_width, g_height; -int g_width_list, g_height_list; GtkWidget *g_window; -GtkWidget *g_theme_view; -GtkCellRenderer *g_renderer; -CustomList *customlist; - -// The data columns that we export via the tree model interface -GtkListStore *g_store; -enum { COL_THEME_FILE = 0, COL_SNAPSHOT, NB_COL, }; -static void custom_list_append(const gchar *name); -#define STEP 0.01 -static gboolean increasing = TRUE; -//gboolean increase_timeout(GtkCellRenderer *renderer); static GtkUIManager *globalUIManager = NULL; static void menuAddWidget (GtkUIManager *, GtkWidget *, GtkContainer *); -static GtkWidget *create_view(); // action on menus -static void menuAdd (GtkWindow * parent); -static void menuSaveAs (GtkWindow *parent); -static void menuDelete (void); -static void menuProperties (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); +static void menuAdd(); +static void menuSaveAs(); +static void menuDelete(); +static void menuProperties(); +static void menuQuit(); +static void menuRefresh(); +static void menuRefreshAll(); +static void menuApply(); +static void menuAbout(); static gboolean view_onPopupMenu (GtkWidget *treeview, gpointer userdata); static gboolean view_onButtonPressed (GtkWidget *treeview, GdkEventButton *event, gpointer userdata); -static void viewRowActivated( GtkTreeView *tree_view, GtkTreePath *path, GtkTreeViewColumn *column, gpointer user_data); +static void windowSizeAllocated(); +static void viewRowActivated(GtkTreeView *tree_view, GtkTreePath *path, GtkTreeViewColumn *column, gpointer user_data); // theme files +static void selectTheme(const gchar *name); +static gboolean searchTheme(const gchar *name_theme, GtkTreeModel *model, GtkTreeIter *iter); static void load_theme(); +static void initTheme(); static void read_config(); static void write_config(); -static void check_theme(); // define menubar, toolbar and popup @@ -93,8 +83,8 @@ static const char *global_ui = " " " " " " - " " - " " +// " " +// " " " " " " " " @@ -108,12 +98,13 @@ static const char *global_ui = " " " " " " - " " " " + " " " " " " - " " + " " " " + " " " " " " " " @@ -146,15 +137,14 @@ int main (int argc, char ** argv) gtk_init (&argc, &argv); g_thread_init( NULL ); read_config(); - check_theme(); - g_width = 300; - g_height = 400; + initTheme(); // define main layout : container, menubar, toolbar g_window = gtk_window_new (GTK_WINDOW_TOPLEVEL); gtk_window_set_title(GTK_WINDOW(g_window), _("Panel theming")); gtk_window_resize(GTK_WINDOW(g_window), g_width, g_height); - g_signal_connect (G_OBJECT (g_window), "destroy", G_CALLBACK (menuQuit), NULL); + g_signal_connect(G_OBJECT(g_window), "destroy", G_CALLBACK (menuQuit), NULL); + g_signal_connect(g_window, "size-allocate", G_CALLBACK(windowSizeAllocated), NULL); vBox = gtk_vbox_new (FALSE, 0); gtk_container_add (GTK_CONTAINER(g_window), vBox); @@ -180,139 +170,12 @@ int main (int argc, char ** argv) // load themes load_theme(g_theme_view); - // rig up idle/thread routines - //Glib::Thread::create(sigc::mem_fun(window.view, &Thumbview::load_cache_images), true); - //Glib::Thread::create(sigc::mem_fun(window.view, &Thumbview::create_cache_images), true); - gtk_widget_show_all(g_window); gtk_main (); return 0; } -GtkWidget *create_view() -{ - GtkTreeViewColumn *col; - GtkCellRenderer *renderer; - GtkWidget *view; - - g_store = gtk_list_store_new(NB_COL, G_TYPE_STRING, GDK_TYPE_PIXBUF); -// g_store = gtk_list_store_new(NB_COL, G_TYPE_STRING, G_TYPE_STRING, G_TYPE_FLOAT); - - view = gtk_tree_view_new_with_model(GTK_TREE_MODEL(g_store)); - gtk_tree_view_set_rules_hint(GTK_TREE_VIEW(view), TRUE); - //gtk_tree_view_set_fixed_height_mode(GTK_TREE_VIEW(view), TRUE); - - g_object_unref(g_store); // destroy store automatically with view - - renderer = gtk_cell_renderer_text_new(); - col = gtk_tree_view_column_new(); - gtk_tree_view_column_pack_start (col, renderer, TRUE); - gtk_tree_view_column_add_attribute (col, renderer, "text", COL_THEME_FILE); - gtk_tree_view_column_set_title (col, "Theme"); - gtk_tree_view_append_column(GTK_TREE_VIEW(view),col); - - g_width_list = 200; - g_height_list = 30; - g_renderer = gtk_cell_renderer_pixbuf_new(); - g_object_set(g_renderer, "xalign", 0.0, NULL); - gtk_cell_renderer_set_fixed_size(g_renderer, g_width_list, g_height_list); - col = gtk_tree_view_column_new(); - gtk_tree_view_column_pack_start(col, g_renderer, TRUE); - gtk_tree_view_column_add_attribute(col, g_renderer, "pixbuf", COL_SNAPSHOT); - gtk_tree_view_column_set_title(col, "Snapshot"); - gtk_tree_view_append_column(GTK_TREE_VIEW(view),col); -/* - renderer = custom_list_new(); - col = gtk_tree_view_column_new(); - gtk_tree_view_column_pack_start (col, renderer, TRUE); - gtk_tree_view_column_add_attribute (col, renderer, "snapshot", COL_SNAPSHOT); - gtk_tree_view_column_set_title (col, "Snapshot"); - gtk_tree_view_append_column(GTK_TREE_VIEW(view),col); -*/ - //g_timeout_add(50, (GSourceFunc) increase_timeout, NULL); - - return view; -} - - -/* -gboolean increase_timeout (GtkCellRenderer *renderer) -{ - GtkTreeIter iter; - gfloat perc = 0.0; - //gchar buf[20]; - - gtk_tree_model_get_iter_first(GTK_TREE_MODEL(g_store), &iter); - - gtk_tree_model_get (GTK_TREE_MODEL(g_store), &iter, COL_SNAPSHOT, &perc, -1); - - if ( perc > (1.0-STEP) || (perc < STEP && perc > 0.0) ) - { - increasing = (!increasing); - } - - if (increasing) - perc = perc + STEP; - else - perc = perc - STEP; - - //g_snprintf(buf, sizeof(buf), "%u %%", (guint)(perc*100)); - - gtk_list_store_set (g_store, &iter, COL_SNAPSHOT, perc, -1); - - return TRUE; -} -*/ -/***************************************************************************** - * - * custom_list_append_record: Empty lists are boring. This function can - * be used in your own code to add rows to the - * list. Note how we emit the "row-inserted" - * signal after we have appended the row - * internally, so the tree view and other - * interested objects know about the new row. - * - *****************************************************************************/ - -void custom_list_append(const gchar *name) -{ - GtkTreeIter iter; - gchar *snap, *cmd; - gint pixWidth, pixHeight; - gboolean changeSize = FALSE; - GdkPixbuf *icon; - - // build panel's snapshot - snap = g_build_filename (g_get_user_config_dir(), "tint2", "snap.jpg", NULL); - cmd = g_strdup_printf("tint2 -c %s -s %s", name, snap); - system(cmd); - g_free(cmd); - - // load - icon = gdk_pixbuf_new_from_file(snap, NULL); - g_free(snap); - if (!icon) - return; - - pixWidth = gdk_pixbuf_get_width(icon); - pixHeight = gdk_pixbuf_get_height(icon); - if (g_width_list < pixWidth) { - g_width_list = pixWidth; - changeSize = TRUE; - } - if (g_height_list < (pixHeight+6)) { - g_height_list = pixHeight+6; - changeSize = TRUE; - } - if (changeSize) - gtk_cell_renderer_set_fixed_size(g_renderer, g_width_list, g_height_list); - - gtk_list_store_append(g_store, &iter); - gtk_list_store_set(g_store, &iter, COL_THEME_FILE, name, COL_SNAPSHOT, icon, -1); -} - - static void menuAddWidget (GtkUIManager * p_uiManager, GtkWidget * p_widget, GtkContainer * p_box) { gtk_box_pack_start(GTK_BOX(p_box), p_widget, FALSE, FALSE, 0); @@ -320,11 +183,11 @@ static void menuAddWidget (GtkUIManager * p_uiManager, GtkWidget * p_widget, Gtk } -static void menuAbout(GtkWindow * parent) +static void menuAbout() { const char *authors[] = { "Thierry Lorthiois ", "Andreas Fink ", "Christian Ruppert (Build system)", "Euan Freeman (tintwizard)\n See http://code.google.com/p/tintwizard/", NULL }; - gtk_show_about_dialog( parent, "name", g_get_application_name( ), + gtk_show_about_dialog(g_window, "name", g_get_application_name( ), "comments", _("Theming tool for tint2 panel"), "version", VERSION_STRING, "copyright", _("Copyright 2009 tint2 team\nTint2 License GNU GPL version 2\nTintwizard License GNU GPL version 3"), @@ -333,17 +196,17 @@ static void menuAbout(GtkWindow * parent) your name to have it appear in the credits in the "About" dialog */ "translator-credits", _("translator-credits"), - NULL ); + NULL); } -static void menuAdd (GtkWindow *parent) +static void menuAdd() { GtkWidget *dialog; GtkFileChooser *chooser; GtkFileFilter *filter; - dialog = gtk_file_chooser_dialog_new(_("Add a theme"), parent, GTK_FILE_CHOOSER_ACTION_OPEN, GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL, GTK_STOCK_ADD, GTK_RESPONSE_ACCEPT, NULL); + dialog = gtk_file_chooser_dialog_new(_("Add a theme"), g_window, GTK_FILE_CHOOSER_ACTION_OPEN, GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL, GTK_STOCK_ADD, GTK_RESPONSE_ACCEPT, NULL); chooser = GTK_FILE_CHOOSER(dialog); gtk_file_chooser_set_current_folder(chooser, g_get_home_dir()); @@ -354,76 +217,116 @@ static void menuAdd (GtkWindow *parent) gtk_file_filter_add_pattern(filter, "*.tint2rc"); gtk_file_chooser_add_filter(chooser, filter); - if (gtk_dialog_run (GTK_DIALOG(dialog)) == GTK_RESPONSE_ACCEPT) { - GSList *l, *list = gtk_file_chooser_get_filenames(chooser); - - gchar *file, *pt1, *name, *path; - for (l = list; l ; l = l->next) { - file = (char *)l->data; - pt1 = strrchr (file, '/'); - if (pt1) { - pt1++; - if (*pt1) { - name = g_strdup(pt1); - path = g_build_filename (g_get_user_config_dir(), "tint2", name, NULL); - copy_file(file, path); - custom_list_append(path); - g_free(path); - g_free(name); - } - } + if (gtk_dialog_run (GTK_DIALOG(dialog)) != GTK_RESPONSE_ACCEPT) { + gtk_widget_destroy(dialog); + return; + } + + GtkTreeIter iter; + GtkTreeModel *model = gtk_tree_view_get_model(GTK_TREE_VIEW(g_theme_view)); + GSList *l, *list = gtk_file_chooser_get_filenames(chooser); + gchar *file, *pt1, *name, *path, *name_first=NULL; + for (l = list; l ; l = l->next) { + file = (char *)l->data; + pt1 = strrchr(file, '/'); + if (pt1 == NULL) continue; + pt1++; + if (*pt1 == 0) continue; + + name = g_strdup(pt1); + path = g_build_filename (g_get_user_config_dir(), "tint2", name, NULL); + + // check existing + if (searchTheme(path, model, &iter)) { + gchar *message; + message = g_strdup_printf(_("Couldn't add duplicate theme\n\'%s\'."), pt1); + + GtkWidget *w = gtk_message_dialog_new(g_window, 0, GTK_MESSAGE_ERROR, GTK_BUTTONS_CLOSE, message, NULL); + g_signal_connect_swapped(w, "response", G_CALLBACK(gtk_widget_destroy), w); + gtk_widget_show(w); + g_free(message); + continue; } - g_slist_foreach(list, (GFunc)g_free, NULL); - g_slist_free(list); + // append theme + copy_file(file, path); + custom_list_append(path); + if (name_first == NULL) + name_first = g_strdup(path); + g_free(path); + g_free(name); } - gtk_widget_destroy (dialog); + g_slist_foreach(list, (GFunc)g_free, NULL); + g_slist_free(list); + gtk_widget_destroy(dialog); + + selectTheme(name_first); + g_free(name_first); + g_timeout_add(SNAPSHOT_TICK, (GSourceFunc)update_snapshot, NULL); } -static void menuSaveAs (GtkWindow *parent) +static void menuSaveAs () { GtkWidget *dialog; GtkFileChooser *chooser; + GtkTreeSelection *sel; + GtkTreeIter iter; + GtkTreeModel *model; + gchar *file, *pt1; + + sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(g_theme_view)); + if (!gtk_tree_selection_get_selected(GTK_TREE_SELECTION(sel), &model, &iter)) { + GtkWidget *w = gtk_message_dialog_new(g_window, 0, GTK_MESSAGE_ERROR, GTK_BUTTONS_CLOSE, _("Select the theme to be saved."), NULL); + g_signal_connect_swapped(w, "response", G_CALLBACK(gtk_widget_destroy), w); + gtk_widget_show(w); + return; + } + + gtk_tree_model_get(model, &iter, COL_THEME_FILE, &file, -1); + pt1 = strrchr (file, '/'); + if (pt1) pt1++; - dialog = gtk_file_chooser_dialog_new (_("Save theme as"), parent, GTK_FILE_CHOOSER_ACTION_SAVE, GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL, GTK_STOCK_SAVE, GTK_RESPONSE_ACCEPT, NULL); + dialog = gtk_file_chooser_dialog_new(_("Save theme as"), g_window, GTK_FILE_CHOOSER_ACTION_SAVE, GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL, GTK_STOCK_SAVE, GTK_RESPONSE_ACCEPT, NULL); chooser = GTK_FILE_CHOOSER(dialog); - gtk_file_chooser_set_do_overwrite_confirmation (chooser, TRUE); - gtk_file_chooser_set_current_folder (chooser, g_get_home_dir()); - gtk_file_chooser_set_current_name (chooser, _("Untitled document")); + gtk_file_chooser_set_do_overwrite_confirmation(chooser, TRUE); + gtk_file_chooser_set_current_folder(chooser, g_get_home_dir()); + gtk_file_chooser_set_current_name(chooser, pt1); - if (gtk_dialog_run (GTK_DIALOG(dialog)) == GTK_RESPONSE_ACCEPT) { + if (gtk_dialog_run(GTK_DIALOG(dialog)) == GTK_RESPONSE_ACCEPT) { char *filename = gtk_file_chooser_get_filename(chooser); - printf("fichier %s\n", filename); - //save_to_file (filename); + copy_file(file, filename); g_free (filename); } + g_free(file); gtk_widget_destroy (dialog); } -static void menuDelete (void) +static void menuDelete() { GtkTreeSelection *sel; GtkTreeIter iter; GtkTreeModel *model; - char *file; + gchar *filename; 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_THEME_FILE, &file, -1); + gtk_tree_model_get(model, &iter, COL_THEME_FILE, &filename, -1); gtk_tree_selection_unselect_all(sel); - // remove (gui and disk) + // remove (gui and file) gtk_list_store_remove(GTK_LIST_STORE(model), &iter); - g_remove(file); - g_free(file); + GFile *file = g_file_new_for_path(filename); + g_file_trash(file, NULL, NULL); + g_object_unref(G_OBJECT(file)); + g_free(filename); } } -static void menuProperties (void) +static void menuProperties() { GtkTreeSelection *sel; GtkTreeIter iter; @@ -434,7 +337,8 @@ static void menuProperties (void) if (gtk_tree_selection_get_selected(GTK_TREE_SELECTION(sel), &model, &iter)) { gtk_tree_model_get(model, &iter, COL_THEME_FILE, &file, -1); - cmd = g_strdup_printf("tintwizard.py \'%s\'", file); + //cmd = g_strdup_printf("gedit \'%s\' &", file); + cmd = g_strdup_printf("tintwizard.py \'%s\' &", file); system(cmd); g_free(cmd); @@ -443,45 +347,68 @@ static void menuProperties (void) } -static void menuQuit (void) +static void menuQuit() { write_config(); + + if (g_path_config) + g_free(g_path_config); + if (g_path_dir) + g_free(g_path_dir); + if (g_default_theme) + g_free(g_default_theme); + gtk_main_quit (); } -static void menuRefresh (void) +static void menuRefresh() { - printf("menuRefresh\n"); -} + GtkTreeSelection *sel; + GtkTreeIter iter; + GtkTreeModel *model; + 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_list_store_set(g_store, &iter, COL_SNAPSHOT, NULL, -1); + } -static void menuRefreshAll (void) -{ - printf("menuRefreshAll\n"); + g_timeout_add(SNAPSHOT_TICK, (GSourceFunc)update_snapshot, NULL); } -static void menuPreferences (void) +static void menuRefreshAll() { - printf("menuPreferences\n"); + GtkTreeIter iter; + GtkTreeModel *model; + gboolean have_iter; + + model = gtk_tree_view_get_model(GTK_TREE_VIEW(g_theme_view)); + have_iter = gtk_tree_model_get_iter_first(model, &iter); + while (have_iter) { + gtk_list_store_set(g_store, &iter, COL_SNAPSHOT, NULL, -1); + have_iter = gtk_tree_model_iter_next(model, &iter); + } + + g_timeout_add(SNAPSHOT_TICK, (GSourceFunc)update_snapshot, NULL); } -static void menuApply (void) +static void menuApply() { GtkTreeSelection *sel; GtkTreeIter iter; GtkTreeModel *model; - char *file; + if (g_default_theme) { + g_free(g_default_theme); + g_default_theme = NULL; + } 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_THEME_FILE, &file, -1); - + gtk_tree_model_get(model, &iter, COL_THEME_FILE, &g_default_theme, -1); // overwrite tint2rc - copy_file(file, g_path_config); - g_free(file); + copy_file(g_default_theme, g_path_config); // restart panel system("killall -SIGUSR1 tint2"); @@ -536,11 +463,21 @@ static void viewRowActivated(GtkTreeView *tree_view, GtkTreePath *path, GtkTreeV } +static void windowSizeAllocated() +{ + const gboolean isMaximized = g_window->window && (gdk_window_get_state(g_window->window) & GDK_WINDOW_STATE_MAXIMIZED); + + if(!isMaximized) + gtk_window_get_size(GTK_WINDOW(g_window), &g_width, &g_height); +} + + static void load_theme(GtkWidget *list) { GDir *dir; - gchar *pt1, *name, *file; - int found_theme = FALSE; + gchar *pt1, *name; + const gchar *file; + gboolean found_theme = FALSE; dir = g_dir_open(g_path_dir, 0, NULL); if (dir == NULL) return; @@ -549,7 +486,7 @@ static void load_theme(GtkWidget *list) if (pt1) { found_theme = TRUE; name = g_build_filename (g_path_dir, file, NULL); - custom_list_append(name); + custom_list_append(name); g_free(name); } } @@ -557,23 +494,75 @@ static void load_theme(GtkWidget *list) if (!found_theme) { // create default theme file - name = g_build_filename (g_get_user_config_dir(), "tint2", "default.tint2rc", NULL); + name = g_build_filename(g_get_user_config_dir(), "tint2", "default.tint2rc", NULL); copy_file(g_path_config, name); - custom_list_append(name); + custom_list_append(name); + if (g_default_theme) g_free(g_default_theme); + g_default_theme = strdup(name); g_free(name); } - // search default theme + selectTheme(g_default_theme); + + g_timeout_add(SNAPSHOT_TICK, (GSourceFunc)update_snapshot, NULL); +} + + +void selectTheme(const gchar *name_theme) +{ + gboolean have_iter, found_theme; GtkTreeIter iter; GtkTreeModel *model; - if (g_default_theme != NULL) { - printf("loadTheme : defaultTheme %s\n", g_default_theme); - //gtk_tree_selection_select_iter(GtkTreeSelection *selection, GtkTreeIter *iter); + + if (!name_theme) return; + + model = gtk_tree_view_get_model(GTK_TREE_VIEW(g_theme_view)); + found_theme = searchTheme(name_theme, model, &iter); + + GtkTreePath *path = NULL; + if (found_theme) + path = gtk_tree_model_get_path(model, &iter); + else { + have_iter = gtk_tree_model_get_iter_first(model, &iter); + if (have_iter) + path = gtk_tree_model_get_path(model, &iter); } + if (path) { + gtk_tree_selection_select_iter(gtk_tree_view_get_selection(GTK_TREE_VIEW(g_theme_view)), &iter); + gtk_tree_view_scroll_to_cell(GTK_TREE_VIEW(g_theme_view), path, NULL, FALSE, 0, 0); + gtk_tree_path_free(path); + } +} + + +gboolean searchTheme(const gchar *name_theme, GtkTreeModel *model, GtkTreeIter *iter) +{ + gchar *name; + gboolean have_iter, found = FALSE; + + have_iter = gtk_tree_model_get_iter_first(model, iter); + while (have_iter) { + gtk_tree_model_get(model, iter, COL_THEME_FILE, &name, -1); + found = (strcmp(name, name_theme) == 0); + g_free(name); + if (found) + break; + have_iter = gtk_tree_model_iter_next(model, iter); + } + return found; +} + + +void initTheme() +{ + g_path_dir = g_build_filename (g_get_user_config_dir(), "tint2", NULL); + if (!g_file_test (g_path_dir, G_FILE_TEST_IS_DIR)) + g_mkdir(g_path_dir, 0777); + + g_path_config = g_build_filename (g_get_user_config_dir(), "tint2", "tint2rc", NULL); } -// theme file management void read_config() { char *path; @@ -583,7 +572,7 @@ void read_config() g_default_theme = NULL; } - g_width = 600; + g_width = 500; g_height = 350; path = g_build_filename (g_get_user_config_dir(), "tint2", "tint2confrc", NULL); if (g_file_test (path, G_FILE_TEST_EXISTS)) { @@ -607,8 +596,6 @@ void read_config() } } g_free(path); - if (g_default_theme != NULL) - printf("readConfig : defaultTheme %s\n", g_default_theme); } @@ -616,28 +603,7 @@ void write_config() { char *path; FILE *fp; - GtkRequisition req; - int x, y, width, height, depth; - int top, bottom, left, right; - GdkRectangle rect; - - gtk_window_get_size(GTK_WINDOW(g_window), &width, &height); - printf("write_config %d, %d\n", width, height); - - // GTK incapacity to return (width, height) of the window is really annoying - gdk_window_get_geometry(GTK_WIDGET(g_window)->window, &x, &y, &width, &height, &depth); - printf(" write_config %d, %d, %d, %d\n", x, y, width, height); - - //Window xid = GDK_WINDOW_XWINDOW(GTK_WIDGET(g_window)->window); - //gdk_window_get_frame_extentsGTK_WINDOW(g_window), &rect); - //printf(" write_config %d, %d\n", rec.width, rec.height); - -/* - path = gtk_tree_path_new_from_indices( playlist_pos, -1 ); - sel = gtk_tree_view_get_selection( (GtkTreeView*)list_view ); - gtk_tree_selection_select_path( sel, path ); - gtk_tree_path_free( path ); - */ + path = g_build_filename (g_get_user_config_dir(), "tint2", "tint2confrc", NULL); fp = fopen(path, "w"); if (fp != NULL) { @@ -656,15 +622,4 @@ void write_config() } -void check_theme() -{ - g_path_dir = g_build_filename (g_get_user_config_dir(), "tint2", NULL); - if (!g_file_test (g_path_dir, G_FILE_TEST_IS_DIR)) - g_mkdir(g_path_dir, 0777); - - g_path_config = g_build_filename (g_get_user_config_dir(), "tint2", "tint2rc", NULL); - -} - -