[easytag/wip/application-window: 49/54] Use GtkTreeView interactive search in CDDB dialog



commit 105af5b6c8240d8210de91e131327a7f2dc7c7b9
Author: David King <amigadave amigadave com>
Date:   Wed Sep 3 16:06:33 2014 +0100

    Use GtkTreeView interactive search in CDDB dialog
    
    Remove custom code to search within results.

 src/cddb_dialog.c |  241 +----------------------------------------------------
 src/setting.c     |   16 ----
 src/setting.h     |    4 -
 3 files changed, 2 insertions(+), 259 deletions(-)
---
diff --git a/src/cddb_dialog.c b/src/cddb_dialog.c
index 63c18f5..4c64a13 100644
--- a/src/cddb_dialog.c
+++ b/src/cddb_dialog.c
@@ -66,11 +66,9 @@ struct _EtCDDBDialogPrivate
 
     GtkListStore *album_list_model;
     GtkListStore *search_string_model;
-    GtkListStore *search_string_in_result_model;
     GtkListStore *track_list_model;
 
     GtkWidget *search_string_entry;
-    GtkWidget *search_string_in_results_entry;
 
     GtkWidget *apply_button;
     GtkWidget *search_button;
@@ -291,191 +289,6 @@ update_search_button_sensitivity (EtCDDBDialog *self)
 }
 
 /*
- * Searches the Cddb Album List for specific terms
- * (this is not search the remote CDDB database...)
- */
-static void
-find_previous_string_in_results (EtCDDBDialog *self)
-{
-    EtCDDBDialogPrivate *priv;
-    gchar *string;
-    gchar  buffer[256];
-    gchar *pbuffer;
-    gchar *text;
-    gchar *temp;
-    GtkTreeSelection* treeSelection;
-    GtkTreeIter iter;
-    GtkTreePath *rowpath;
-    gboolean itemselected = FALSE;
-
-    priv = et_cddb_dialog_get_instance_private (self);
-
-    string = g_strdup(gtk_entry_get_text(GTK_ENTRY(priv->search_string_in_results_entry)));
-    if (!string || strlen(string)==0)
-        return;
-    temp = g_utf8_strdown(string, -1);
-    g_free(string);
-    string = temp;
-
-    Add_String_To_Combo_List(priv->search_string_in_result_model, string);
-
-    /* Get the currently selected row into &iter and set itemselected to reflect this */
-    treeSelection = gtk_tree_view_get_selection(GTK_TREE_VIEW(priv->album_list_view));
-    if (gtk_tree_selection_get_selected(treeSelection, NULL, &iter) == TRUE)
-        itemselected = TRUE;
-
-    /* Previous result button */
-
-    /* Search in the album list (from bottom/selected-item to top) */
-    if (itemselected == TRUE)
-    {
-        rowpath = gtk_tree_model_get_path(GTK_TREE_MODEL(priv->album_list_model), &iter);
-        gtk_tree_path_prev(rowpath);
-    } else
-    {
-        rowpath = 
gtk_tree_path_new_from_indices(gtk_tree_model_iter_n_children(GTK_TREE_MODEL(priv->album_list_model), NULL) - 
1, -1);
-    }
-
-    do
-    {
-        gboolean found;
-
-        found = gtk_tree_model_get_iter(GTK_TREE_MODEL(priv->album_list_model), &iter, rowpath);
-        if (found)
-        {
-            gtk_tree_model_get(GTK_TREE_MODEL(priv->album_list_model), &iter, CDDB_ALBUM_LIST_ALBUM, &text, 
-1);
-            g_utf8_strncpy(buffer,text,256);
-            temp = g_utf8_strdown(buffer, -1);
-            pbuffer = temp;
-
-            if (pbuffer && strstr(pbuffer,string) != NULL)
-            {
-                gtk_tree_selection_select_iter(treeSelection, &iter);
-                gtk_tree_view_scroll_to_cell(GTK_TREE_VIEW(priv->album_list_view), rowpath, NULL, FALSE, 0, 
0);
-                gtk_tree_path_free(rowpath);
-                g_free(text);
-                g_free(temp);
-                g_free(string);
-                return;
-            }
-            g_free(temp);
-            g_free(text);
-        }
-    } while(gtk_tree_path_prev(rowpath));
-    gtk_tree_path_free(rowpath);
-}
-
-static void
-find_next_string_in_results (EtCDDBDialog *self)
-{
-    EtCDDBDialogPrivate *priv;
-    gchar *string;
-    gchar  buffer[256];
-    gchar *pbuffer;
-    gchar *text;
-    gchar *temp;
-    gint   i;
-    gint  rowcount;
-    GtkTreeSelection* treeSelection;
-    GtkTreeIter iter;
-    GtkTreePath *rowpath;
-    gboolean result;
-    gboolean itemselected = FALSE;
-    GtkTreeIter itercopy;
-
-    priv = et_cddb_dialog_get_instance_private (self);
-
-    string = g_strdup (gtk_entry_get_text (GTK_ENTRY (priv->search_string_in_results_entry)));
-    if (!string || strlen(string)==0)
-        return;
-    temp = g_utf8_strdown(string, -1);
-    g_free(string);
-    string = temp;
-
-    Add_String_To_Combo_List(priv->search_string_in_result_model, string);
-
-    /* Get the currently selected row into &iter and set itemselected to reflect this */
-    treeSelection = gtk_tree_view_get_selection(GTK_TREE_VIEW(priv->album_list_view));
-    if (gtk_tree_selection_get_selected(treeSelection, NULL, &iter) == TRUE)
-        itemselected = TRUE;
-
-    rowcount = gtk_tree_model_iter_n_children(GTK_TREE_MODEL(priv->album_list_model), NULL);
-
-    /* Search in the album list (from top to bottom) */
-    if (itemselected == TRUE)
-    {
-        gtk_tree_selection_unselect_iter(treeSelection, &iter);
-        result = gtk_tree_model_iter_next(GTK_TREE_MODEL(priv->album_list_model), &iter);
-    } else
-    {
-        result = gtk_tree_model_get_iter_first(GTK_TREE_MODEL(priv->album_list_model), &iter);
-    }
-
-    itercopy = iter;
-
-    /* If list entries follow the previously selected item, loop through them looking for a match */
-    if(result == TRUE)
-    {
-        do /* Search following results */
-        {
-            gtk_tree_model_get(GTK_TREE_MODEL(priv->album_list_model), &iter, CDDB_ALBUM_LIST_ALBUM, &text, 
-1);
-            g_utf8_strncpy(buffer, text, 256);
-
-            temp = g_utf8_strdown(buffer, -1);
-            pbuffer = temp;
-
-            if (pbuffer && strstr(pbuffer, string) != NULL)
-            {
-                gtk_tree_selection_select_iter(treeSelection, &iter);
-                rowpath = gtk_tree_model_get_path(GTK_TREE_MODEL(priv->album_list_model), &iter);
-                gtk_tree_view_scroll_to_cell(GTK_TREE_VIEW(priv->album_list_view), rowpath, NULL, FALSE, 0, 
0);
-                gtk_tree_path_free(rowpath);
-                g_free(text);
-                g_free(temp);
-                g_free(string);
-                return;
-            }
-            g_free(temp);
-            g_free(text);
-        } while(gtk_tree_model_iter_next(GTK_TREE_MODEL(priv->album_list_model), &iter));
-    }
-
-    for (i = 0; i < rowcount; i++)
-    {
-        gboolean found;
-
-        if (i == 0)
-            found = gtk_tree_model_get_iter_first(GTK_TREE_MODEL(priv->album_list_model), &itercopy);
-        else
-            found = gtk_tree_model_iter_next(GTK_TREE_MODEL(priv->album_list_model), &itercopy);
-
-        if (found)
-        {
-            gtk_tree_model_get(GTK_TREE_MODEL(priv->album_list_model), &itercopy, CDDB_ALBUM_LIST_ALBUM, 
&text, -1);
-            g_utf8_strncpy(buffer, text, 256);
-
-            temp = g_utf8_strdown(buffer, -1);
-            pbuffer = temp;
-
-            if (pbuffer && strstr(pbuffer,string) != NULL)
-            {
-                gtk_tree_selection_select_iter(treeSelection, &itercopy);
-                rowpath = gtk_tree_model_get_path(GTK_TREE_MODEL(priv->album_list_model), &itercopy);
-                gtk_tree_view_scroll_to_cell(GTK_TREE_VIEW(priv->album_list_view), rowpath, NULL, FALSE, 0, 
0);
-                gtk_tree_path_free(rowpath);
-                g_free(text);
-                g_free(temp);
-                g_free(string);
-                return;
-            }
-            g_free(temp);
-            g_free(text);
-        }
-    }
-    g_free(string);
-}
-
-/*
  * Show collected infos of the album in the status bar
  */
 static void
@@ -3243,57 +3056,6 @@ create_cddb_dialog (EtCDDBDialog *self)
     hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, BOX_SPACING);
     gtk_container_add(GTK_CONTAINER(Frame),hbox);
 
-    Label = gtk_label_new(_("Search:"));
-    gtk_widget_set_halign (Label, GTK_ALIGN_END);
-    gtk_box_pack_start(GTK_BOX(hbox),Label,FALSE,FALSE,0);
-
-    g_assert (priv->search_string_in_result_model == NULL);
-    priv->search_string_in_result_model = gtk_list_store_new (MISC_COMBO_COUNT,
-                                                        G_TYPE_STRING);
-
-    combo = gtk_combo_box_new_with_model_and_entry (GTK_TREE_MODEL (priv->search_string_in_result_model));
-    g_object_unref (priv->search_string_in_result_model);
-    gtk_combo_box_set_entry_text_column (GTK_COMBO_BOX (combo),
-                                         MISC_COMBO_TEXT);
-    gtk_box_pack_start (GTK_BOX (hbox), combo, FALSE, FALSE, 0);
-    priv->search_string_in_results_entry = gtk_bin_get_child (GTK_BIN (combo));
-    g_signal_connect_swapped (priv->search_string_in_results_entry,
-                              "activate",
-                              G_CALLBACK (find_next_string_in_results),
-                              self);
-    gtk_widget_set_tooltip_text (priv->search_string_in_results_entry,
-                                 _("Enter the words to search in the list below"));
-
-    /* History List. */
-    Load_Cddb_Search_String_In_Result_List(priv->search_string_in_result_model, MISC_COMBO_TEXT);
-
-    gtk_entry_set_text (GTK_ENTRY (priv->search_string_in_results_entry), "");
-
-    Button = gtk_button_new ();
-    gtk_container_add (GTK_CONTAINER (Button),
-                       gtk_image_new_from_icon_name ("go-down",
-                                                     GTK_ICON_SIZE_BUTTON));
-    gtk_box_pack_start(GTK_BOX(hbox),Button,FALSE,FALSE,0);
-    gtk_button_set_relief(GTK_BUTTON(Button),GTK_RELIEF_NONE);
-    g_signal_connect_swapped (Button, "clicked",
-                              G_CALLBACK (find_next_string_in_results), self);
-    gtk_widget_set_tooltip_text(Button,_("Search Next"));
-
-    Button = gtk_button_new ();
-    gtk_container_add (GTK_CONTAINER (Button),
-                       gtk_image_new_from_icon_name ("go-up",
-                                                     GTK_ICON_SIZE_BUTTON));
-    gtk_box_pack_start (GTK_BOX (hbox), Button, FALSE, FALSE, 0);
-    gtk_button_set_relief (GTK_BUTTON (Button), GTK_RELIEF_NONE);
-    g_signal_connect_swapped (Button, "clicked",
-                              G_CALLBACK (find_previous_string_in_results),
-                              self);
-    gtk_widget_set_tooltip_text (Button, _("Search Previous"));
-
-    // Separator line
-    Separator = gtk_separator_new(GTK_ORIENTATION_VERTICAL);
-    gtk_box_pack_start(GTK_BOX(hbox),Separator,FALSE,FALSE,0);
-
     priv->display_red_lines_toggle = gtk_toggle_button_new();
     Icon = gtk_image_new_from_resource ("/org/gnome/EasyTAG/images/red-lines.png");
     gtk_container_add(GTK_CONTAINER(priv->display_red_lines_toggle),Icon);
@@ -3355,6 +3117,8 @@ create_cddb_dialog (EtCDDBDialog *self)
                                             GDK_TYPE_RGBA);
     priv->album_list_view = gtk_tree_view_new_with_model(GTK_TREE_MODEL(priv->album_list_model));
     g_object_unref (priv->album_list_model);
+    gtk_tree_view_set_search_column (GTK_TREE_VIEW (priv->album_list_view),
+                                     CDDB_ALBUM_LIST_ALBUM);
 
     renderer = gtk_cell_renderer_pixbuf_new();
     column = gtk_tree_view_column_new_with_attributes(_(CddbAlbumList_Titles[0]), renderer,
@@ -3573,7 +3337,6 @@ et_cddb_dialog_apply_changes (EtCDDBDialog *self)
 
     /* Save combobox history lists before exit. */
     Save_Cddb_Search_String_List(priv->search_string_model, MISC_COMBO_TEXT);
-    Save_Cddb_Search_String_In_Result_List(priv->search_string_in_result_model, MISC_COMBO_TEXT);
 }
 
 /*
diff --git a/src/setting.c b/src/setting.c
index 00bb2d4..2e3e24f 100644
--- a/src/setting.c
+++ b/src/setting.c
@@ -75,8 +75,6 @@ static const gchar RUN_PROGRAM_WITH_FILE_HISTORY_FILE[] = "run_program_with_file
 static const gchar SEARCH_FILE_HISTORY_FILE[] = "search_file.history";
 // File for history of CddbSearchStringEntry combobox
 static const gchar CDDB_SEARCH_STRING_HISTORY_FILE[] = "cddb_search_string.history";
-// File for history of CddbSearchStringInResultEntry combobox
-static const gchar CDDB_SEARCH_STRING_IN_RESULT_HISTORY_FILE[] = "cddb_search_string_in_result.history";
 
 
 
@@ -170,7 +168,6 @@ gboolean Setting_Create_Files (void)
     check_or_create_file (RUN_PROGRAM_WITH_FILE_HISTORY_FILE);
     check_or_create_file (SEARCH_FILE_HISTORY_FILE);
     check_or_create_file (CDDB_SEARCH_STRING_HISTORY_FILE);
-    check_or_create_file (CDDB_SEARCH_STRING_IN_RESULT_HISTORY_FILE);
 
     return TRUE;
 }
@@ -402,18 +399,6 @@ void Save_Cddb_Search_String_List (GtkListStore *liststore, gint colnum)
 }
 
 /*
- * Functions for writing and reading list of combobox of cddb search string in result list
- */
-void Load_Cddb_Search_String_In_Result_List (GtkListStore *liststore, gint colnum)
-{
-    Populate_List_Store_From_File(CDDB_SEARCH_STRING_IN_RESULT_HISTORY_FILE, liststore, colnum);
-}
-void Save_Cddb_Search_String_In_Result_List (GtkListStore *liststore, gint colnum)
-{
-    Save_List_Store_To_File(CDDB_SEARCH_STRING_IN_RESULT_HISTORY_FILE, liststore, colnum);
-}
-
-/*
  * migrate_config_to_xdg_dir:
  * @old_path: (type filename): the path to migrate from
  * @new_path: (type filename): the path to migrate to
@@ -433,7 +418,6 @@ migrate_config_file_dir (const gchar *old_path, const gchar *new_path)
                                         RUN_PROGRAM_WITH_FILE_HISTORY_FILE,
                                         SEARCH_FILE_HISTORY_FILE,
                                         CDDB_SEARCH_STRING_HISTORY_FILE,
-                                        CDDB_SEARCH_STRING_IN_RESULT_HISTORY_FILE,
                                         NULL
     };
 
diff --git a/src/setting.h b/src/setting.h
index 15229cd..e3c3aae 100644
--- a/src/setting.h
+++ b/src/setting.h
@@ -272,10 +272,6 @@ void Save_Search_File_List (GtkListStore *liststore, gint colnum);
 void Load_Cddb_Search_String_List (GtkListStore *liststore, gint colnum);
 void Save_Cddb_Search_String_List (GtkListStore *liststore, gint colnum);
 
-/* 'CddbSearchStringInResultEntry' combobox */
-void Load_Cddb_Search_String_In_Result_List (GtkListStore *liststore, gint colnum);
-void Save_Cddb_Search_String_In_Result_List (GtkListStore *liststore, gint colnum);
-
 gboolean et_settings_enum_get (GValue *value, GVariant *variant,
                                gpointer user_data);
 GVariant *et_settings_enum_set (const GValue *value,


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]