X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=src%2Ftint2conf%2Fmain.c;h=49c5e23881b672933a8052804901fea61a3f0b09;hb=94bf7d79dd6b32ba4d8f6b80b4d1efbf5fbb3340;hp=a2d1e53d9b21ba876ecfd95ba2c8cc337084fe36;hpb=55a13efc27289717061f31770c0b9a8fb834561b;p=chaz%2Ftint2 diff --git a/src/tint2conf/main.c b/src/tint2conf/main.c index a2d1e53..49c5e23 100644 --- a/src/tint2conf/main.c +++ b/src/tint2conf/main.c @@ -17,13 +17,19 @@ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. **************************************************************************/ +#include +#include #include #include +#include +#include #include #include #include #include +#include "common.h" + // TODO // ** add, saveas @@ -44,15 +50,19 @@ enum { LIST_ITEM = 0, N_COLUMNS }; // default config file and directory -char *pathConfig = 0; -char *pathDir = 0; +char *g_path_config = 0; +char *g_path_dir = 0; +char *g_default_theme = 0; +int g_width; +int g_height; -GtkWidget *themeView; +GtkWidget *g_window; +GtkWidget *g_theme_view; +GtkListStore *g_store; -static GtkUIManager *myUIManager = NULL; +static GtkUIManager *globalUIManager = NULL; static void menuAddWidget (GtkUIManager *, GtkWidget *, GtkContainer *); -static void viewPopup(GtkWidget *wid,GdkEventButton *event,GtkWidget *menu); // action on menus static void menuAdd (GtkWindow * parent); @@ -66,7 +76,8 @@ static void menuRefreshAll (void); static void menuApply (void); static void menuAbout(GtkWindow * parent); -static void onPopupMenu(GtkWidget *self, GdkEventButton *event); +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); // TreeView @@ -75,10 +86,13 @@ static void init_list(GtkWidget *list); static void add_to_list(GtkWidget *list, const gchar *str); void on_changed(GtkWidget *widget, gpointer label); +void read_config(); +void write_config(); +void check_theme(); -// define menubar and toolbar -static const char *fallback_ui_file = +// define menubar, toolbar and popup +static const char *global_ui = "" " " " " @@ -106,8 +120,15 @@ static const char *fallback_ui_file = " " " " " " + " " + " " + " " + " " + " " + " " ""; + // define menubar and toolbar action static GtkActionEntry entries[] = { {"ThemeMenu", NULL, "Theme", NULL, NULL, NULL}, @@ -128,75 +149,62 @@ static GtkActionEntry entries[] = { int main (int argc, char ** argv) { - GtkWidget *window, *popup, *item; GtkWidget *vBox = NULL; GtkActionGroup *actionGroup; - GtkTreeViewColumn *col; GtkTreeSelection *sel; gtk_init (&argc, &argv); g_thread_init( NULL ); - checkConfig(); + read_config(); + check_theme(); // define main layout : container, menubar, toolbar - window = gtk_window_new (GTK_WINDOW_TOPLEVEL); - gtk_window_set_title(GTK_WINDOW(window), _("Panel theming")); - gtk_window_set_default_size(GTK_WINDOW(window), 600, 350); - g_signal_connect (G_OBJECT (window), "destroy", G_CALLBACK (menuQuit), NULL); + 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); vBox = gtk_vbox_new (FALSE, 0); - gtk_container_add (GTK_CONTAINER(window), vBox); + gtk_container_add (GTK_CONTAINER(g_window), vBox); actionGroup = gtk_action_group_new ("menuActionGroup"); gtk_action_group_add_actions (actionGroup, entries, G_N_ELEMENTS (entries), NULL); - myUIManager = gtk_ui_manager_new(); - gtk_ui_manager_insert_action_group (myUIManager, actionGroup, 0); - gtk_ui_manager_add_ui_from_string ( myUIManager, fallback_ui_file, -1, NULL ); - g_signal_connect(myUIManager, "add_widget", G_CALLBACK (menuAddWidget), vBox); - gtk_ui_manager_ensure_update(myUIManager); + globalUIManager = gtk_ui_manager_new(); + gtk_ui_manager_insert_action_group (globalUIManager, actionGroup, 0); + gtk_ui_manager_add_ui_from_string (globalUIManager, global_ui, -1, NULL ); + g_signal_connect(globalUIManager, "add_widget", G_CALLBACK (menuAddWidget), vBox); + gtk_ui_manager_ensure_update(globalUIManager); // define tree view - themeView = gtk_tree_view_new(); - gtk_tree_view_set_headers_visible(GTK_TREE_VIEW(themeView), FALSE); - //gtk_tree_view_set_fixed_height_mode(GTK_TREE_VIEW(themeView), TRUE); + g_theme_view = gtk_tree_view_new(); + gtk_tree_view_set_headers_visible(GTK_TREE_VIEW(g_theme_view), FALSE); + //gtk_widget_set_size_request(g_theme_view, g_width, g_height); + //gtk_tree_view_set_fixed_height_mode(GTK_TREE_VIEW(g_theme_view), TRUE); //col = GTK_TREE_VIEW_COLUMN (g_object_new (GTK_TYPE_TREE_VIEW_COLUMN, "title", _("Theme"), "resizable", TRUE, "sizing", GTK_TREE_VIEW_COLUMN_FIXED, NULL)); - sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(themeView)); + sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(g_theme_view)); gtk_tree_selection_set_mode(GTK_TREE_SELECTION(sel), GTK_SELECTION_SINGLE); - gtk_box_pack_start(GTK_BOX(vBox), themeView, TRUE, TRUE, 0); - gtk_widget_show(themeView); - g_signal_connect(themeView, "popup-menu", G_CALLBACK(onPopupMenu), NULL); - g_signal_connect(themeView, "row-activated", G_CALLBACK(viewRowActivated), NULL); + gtk_box_pack_start(GTK_BOX(vBox), g_theme_view, TRUE, TRUE, 0); + gtk_widget_show(g_theme_view); + g_signal_connect(g_theme_view, "button-press-event", (GCallback)view_onButtonPressed, NULL); + g_signal_connect(g_theme_view, "popup-menu", (GCallback)view_onPopupMenu, NULL); + g_signal_connect(g_theme_view, "row-activated", G_CALLBACK(viewRowActivated), NULL); g_signal_connect(sel, "changed", G_CALLBACK(on_changed), NULL); - //g_signal_connect(themeView, "button-press-event", G_CALLBACK(onViewButtonPressed), (void *)onViewButtonPressed); - //g_signal_connect(themeView, "button-release-event", G_CALLBACK(onViewButtonReleased), NULL); GtkCellRenderer *renderer; GtkTreeViewColumn *column; - GtkListStore *store; renderer = gtk_cell_renderer_text_new(); column = gtk_tree_view_column_new_with_attributes("List Items", renderer, "text", LIST_ITEM, NULL); - gtk_tree_view_append_column(GTK_TREE_VIEW(themeView), column); - store = gtk_list_store_new(N_COLUMNS, G_TYPE_STRING); - gtk_tree_view_set_model(GTK_TREE_VIEW(themeView), GTK_TREE_MODEL(store)); - g_object_unref(store); - - // popup menu - // all you need to do is add the GDK_BUTTON_PRESS_MASK to the window's events - gtk_widget_add_events(window, GDK_BUTTON_PRESS_MASK); - popup = gtk_menu_new(); - item = gtk_menu_item_new_with_label("victory"); - gtk_menu_shell_append(GTK_MENU_SHELL(popup), item); - gtk_menu_attach_to_widget(GTK_MENU(popup), window, NULL); - gtk_widget_show_all(popup); - g_signal_connect(G_OBJECT(window),"button-press-event", G_CALLBACK(viewPopup), (gpointer)popup); + gtk_tree_view_append_column(GTK_TREE_VIEW(g_theme_view), column); + g_store = gtk_list_store_new(N_COLUMNS, G_TYPE_STRING); + gtk_tree_view_set_model(GTK_TREE_VIEW(g_theme_view), GTK_TREE_MODEL(g_store)); // load themes - loadTheme(themeView); + loadTheme(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(window); + gtk_widget_show_all(g_window); gtk_main (); return 0; } @@ -209,22 +217,14 @@ static void menuAddWidget (GtkUIManager * p_uiManager, GtkWidget * p_widget, Gtk } -static void viewPopup(GtkWidget *wid, GdkEventButton *event, GtkWidget *menu) -{ - if((event->button == 3) && (event->type == GDK_BUTTON_PRESS)) { - gtk_menu_popup(GTK_MENU(menu),NULL,NULL,NULL,NULL,event->button,event->time); - } -} - - static void menuAbout(GtkWindow * parent) { - const char *authors[] = { "Thierry Lorthiois", "Christian Ruppert (Build system)", NULL }; + const char *authors[] = { "Thierry Lorthiois", "Christian Ruppert (Build system)", "Euan Freeman (tintwizard)\nSee http://code.google.com/p/tintwizard/", NULL }; gtk_show_about_dialog( parent, "name", g_get_application_name( ), "comments", _("Theming tool for tint2 panel"), "version", LONG_VERSION_STRING, - "copyright", _("Copyright 2009 tint2 team\nLicense GNU GPL version 2"), + "copyright", _("Copyright 2009 tint2 team\nTint2 License GNU GPL version 2\nTintwizard License GNU GPL version 3"), "logo-icon-name", NULL, "authors", authors, /* Translators: translate "translator-credits" as your name to have it appear in the credits in the "About" @@ -261,20 +261,19 @@ static void menuAdd (GtkWindow *parent) if (pt1) { pt1++; if (*pt1) { - name = strndup(pt1, 65000); + name = strdup(pt1); path = g_build_filename (g_get_user_config_dir(), "tint2", name, NULL); copy_file(file, path); g_free(path); pt1 = strstr(name, ".tint2rc"); if (pt1) { file = strndup(name, pt1-name); - add_to_list(themeView, file); + add_to_list(g_theme_view, file); g_free(file); } g_free(name); } } - //tr_core_torrents_added( core ); } g_slist_foreach(list, (GFunc)g_free, NULL); @@ -308,24 +307,66 @@ static void menuSaveAs (GtkWindow *parent) static void menuDelete (void) { - printf("menuDelete\n"); + GtkTreeSelection *sel; + GtkTreeIter iter; + GtkTreeModel *model; + char *value, *name1, *name2; + + 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, LIST_ITEM, &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); + g_free(value); + } } static void menuProperties (void) { - printf("menuProperties\n"); + GtkTreeSelection *sel; + GtkTreeIter iter; + GtkTreeModel *model; + char *value, *name1, *name2, *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, LIST_ITEM, &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); + system(cmd); + g_free(cmd); + + g_free(name1); + g_free(name2); + g_free(value); + } } static void menuRename (void) { printf("menuRename\n"); + // g_rename } static void menuQuit (void) { + write_config(); + + g_object_unref(g_store); gtk_main_quit (); } @@ -349,14 +390,16 @@ static void menuApply (void) GtkTreeModel *model; char *value, *name1, *name2; - sel = gtk_tree_view_get_selection(GTK_TREE_VIEW(themeView)); + 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, LIST_ITEM, &value, -1); name1 = g_build_filename (g_get_user_config_dir(), "tint2", value, NULL); name2 = g_strdup_printf("%s.tint2rc", name1); - copy_file(name2, pathConfig); - g_free(value); g_free(name1); + + copy_file(name2, g_path_config); + write_config(); + g_free(value); g_free(name2); // restart panel @@ -365,17 +408,50 @@ static void menuApply (void) } -static void onPopupMenu(GtkWidget *self, GdkEventButton *event) +static void view_popup_menu(GtkWidget *treeview, GdkEventButton *event, gpointer userdata) { - //GtkWidget *menu = action_get_widget("/main-window-popup"); + GtkWidget *w = gtk_ui_manager_get_widget(globalUIManager, "/ThemePopup"); - //gtk_menu_popup(GTK_MENU(menu), NULL, NULL, NULL, NULL, (event ? event->button : 0), (event ? event->time : 0)); + gtk_menu_popup(GTK_MENU(w), NULL, NULL, NULL, NULL, (event != NULL) ? event->button : 0, gdk_event_get_time((GdkEvent*)event)); +} + + +static gboolean view_onButtonPressed (GtkWidget *treeview, GdkEventButton *event, gpointer userdata) +{ + // single click with the right mouse button? + if (event->type == GDK_BUTTON_PRESS && event->button == 3) { + GtkTreeSelection *selection; + + selection = gtk_tree_view_get_selection(GTK_TREE_VIEW(treeview)); + + if (gtk_tree_selection_count_selected_rows(selection) <= 1) { + GtkTreePath *path; + + // Get tree path for row that was clicked + if (gtk_tree_view_get_path_at_pos(GTK_TREE_VIEW(treeview), (gint) event->x, (gint) event->y, &path, NULL, NULL, NULL)) { + gtk_tree_selection_unselect_all(selection); + gtk_tree_selection_select_path(selection, path); + gtk_tree_path_free(path); + } + } + + view_popup_menu(treeview, event, userdata); + return TRUE; + } + return FALSE; +} + + +static gboolean view_onPopupMenu (GtkWidget *treeview, gpointer userdata) +{ + view_popup_menu(treeview, NULL, userdata); + return TRUE; } static void viewRowActivated(GtkTreeView *tree_view, GtkTreePath *path, GtkTreeViewColumn *column, gpointer user_data) { - //action_activate("show-torrent-properties"); + menuApply(); } @@ -384,7 +460,7 @@ static void loadTheme(GtkWidget *list) GDir *dir; gchar *file, *pt1, *name; - dir = g_dir_open(pathDir, 0, NULL); + dir = g_dir_open(g_path_dir, 0, NULL); while ((file = g_dir_read_name(dir))) { pt1 = strstr(file, ".tint2rc"); if (pt1) { @@ -394,38 +470,101 @@ static void loadTheme(GtkWidget *list) } } g_dir_close(dir); + + // search default theme + GtkTreeIter iter; + GtkTreeModel *model; + if (g_default_theme) { + printf("defaultTheme %s\n", g_default_theme); + //gtk_tree_selection_select_iter(GtkTreeSelection *selection, GtkTreeIter *iter); + } } -// config file management +// theme file management +void read_config() +{ + char *path; + + if (g_default_theme) + g_free(g_default_theme); + + g_width = 600; + g_height = 350; + path = g_build_filename (g_get_user_config_dir(), "tint2", "tint2confrc", NULL); + if (g_file_test (path, G_FILE_TEST_EXISTS)) { + FILE *fp; + char line[80]; + char *key, *value; + if ((fp = fopen(path, "r")) != NULL) { + while (fgets(line, sizeof(line), fp) != NULL) { + if (parse_line(line, &key, &value)) { + if (strcmp (key, "default_theme") == 0) + g_default_theme = strdup (value); + else if (strcmp (key, "width") == 0) + g_width = atoi(value); + else if (strcmp (key, "height") == 0) + g_height = atoi(value); + free (key); + free (value); + } + } + fclose (fp); + } + } + g_free(path); +} + -void checkConfig() +void write_config() { - pathDir = g_build_filename (g_get_user_config_dir(), "tint2", NULL); - if (!g_file_test (pathDir, G_FILE_TEST_IS_DIR)) - g_mkdir(pathDir, 0777); + char *path; + FILE *fp; + GtkRequisition req; + int x, y, width, height, depth; + int top, bottom, left, right; + GdkRectangle rect; - pathConfig = g_build_filename (g_get_user_config_dir(), "tint2", "tint2rc", NULL); + 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); -void copy_file(const char *pathSrc, const char *pathDest) -{ - FILE *fileSrc, *fileDest; - char line[100]; - int nb; +/* + 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) { + fputs("#---------------------------------------------\n", fp); + fputs("# TINT2CONF CONFIG FILE\n", fp); + fprintf(fp, "default_theme = %s\n", g_default_theme); + fprintf(fp, "width = %d\n", g_width); + fprintf(fp, "height = %d\n", g_height); + fputs("\n", fp); + fclose (fp); + } + g_free(path); +} - fileSrc = fopen(pathSrc, "rb"); - if (fileSrc == NULL) return; - fileDest = fopen(pathDest, "wb"); - if (fileDest == NULL) return; +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); - while ((nb = fread(line, 1, 100, fileSrc)) > 0) fwrite(line, 1, nb, fileDest); + g_path_config = g_build_filename (g_get_user_config_dir(), "tint2", "tint2rc", NULL); - fclose (fileDest); - fclose (fileSrc); }