[easytag/wip/musicbrainz-support-merge: 137/180] Changed Scan Selected Files for Multiple Files



commit 2e83cf88aaf99b7a9d71c5e8aceab219cc42d3f5
Author: Abhinav <abhijangda hotmail com>
Date:   Fri Aug 22 20:00:13 2014 +0530

    Changed Scan Selected Files for Multiple Files
    
    Changed Scan Selected Files to search for Multiple Albums of Multiple Files.
    Changes in function selected_find_callback, bt_selected_find_clicked, selected_find_thread_func

 src/musicbrainz_dialog.c |  193 +++++++++++++++++++++++++++++++++++-----------
 1 files changed, 149 insertions(+), 44 deletions(-)
---
diff --git a/src/musicbrainz_dialog.c b/src/musicbrainz_dialog.c
index 7867317..ae9c19e 100644
--- a/src/musicbrainz_dialog.c
+++ b/src/musicbrainz_dialog.c
@@ -59,6 +59,11 @@ typedef enum
 
 typedef struct
 {
+    GHashTable *hash_table;
+} SelectedFindThreadData;
+
+typedef struct
+{
     EtMbSearchType type;
 } EtMbSearch;
 
@@ -510,77 +515,177 @@ entry_tree_view_search_changed (GtkEditable *editable, gpointer user_data)
 }
 
 static void
-bt_selected_find_clicked (GtkWidget *widget, gpointer user_data)
+selected_find_callback (GObject *source, GAsyncResult *res,
+                        gpointer user_data)
 {
-    ET_File *et_file;
-    File_Tag *file_tag;
-    GtkWidget *cb_manual_search;
-    GtkWidget *cb_manual_search_in;
-    GtkWidget *entry;
-    int type;
-
-    et_file = NULL;
-    get_first_selected_file (&et_file);
-
-    if (!et_file)
+    if (!g_simple_async_result_get_op_res_gboolean (G_SIMPLE_ASYNC_RESULT (res)))
     {
-        gtk_statusbar_push (GTK_STATUSBAR (gtk_builder_get_object (builder, "statusbar")),
-                        0, _("No File Selected."));
+        g_object_unref (res);
+        g_object_unref (((SelectedFindThreadData *)user_data)->hash_table);
+        g_free (user_data);
+        free_mb_tree (&mb_dialog_priv->mb_tree_root);
+        mb_dialog_priv->mb_tree_root = g_node_new (NULL);
         return;
     }
 
-    file_tag = (File_Tag *)et_file->FileTag->data;
-    cb_manual_search_in = GTK_WIDGET (gtk_builder_get_object (builder,
-                                                              "cbManualSearchIn"));
-    type = gtk_combo_box_get_active (GTK_COMBO_BOX (cb_manual_search_in));
+    et_mb_entity_view_set_tree_root (ET_MB_ENTITY_VIEW (entityView),
+                                     mb_dialog_priv->mb_tree_root);
+    gtk_statusbar_push (GTK_STATUSBAR (gtk_builder_get_object (builder, "statusbar")),
+                        0, _("Searching Completed"));
+    g_object_unref (res);
+    g_hash_table_destroy (((SelectedFindThreadData *)user_data)->hash_table);
+    g_free (user_data);
+    et_music_brainz_dialog_stop_set_sensitive (FALSE);
 
-    if (type == -1)
+    if (exit_on_complete)
     {
-        return;
+        btn_close_clicked (NULL, NULL);
     }
+}
 
-    cb_manual_search = GTK_WIDGET (gtk_builder_get_object (builder,
-                                                           "cbManualSearch"));
-    entry = gtk_bin_get_child (GTK_BIN (cb_manual_search));
+static void
+selected_find_thread_func (GSimpleAsyncResult *res, GObject *obj,
+                           GCancellable *cancellable)
+{
+    GList *list_keys;
+    GList *iter;
+    SelectedFindThreadData *thread_data;
+    GError *error;
+
+    g_simple_async_result_set_op_res_gboolean (res, FALSE);
+    error = NULL;
+    thread_data = (SelectedFindThreadData *)g_async_result_get_user_data (G_ASYNC_RESULT (res));
+    list_keys = g_hash_table_get_keys (thread_data->hash_table);
+    iter = g_list_first (list_keys);
 
-    if (type == MB_ENTITY_KIND_ARTIST)
+    while (iter)
     {
-        if (file_tag->artist && *(file_tag->artist))
+        if (!et_musicbrainz_search ((gchar *)iter->data, MB_ENTITY_KIND_ALBUM,
+                                    mb_dialog_priv->mb_tree_root, &error,
+                                    cancellable))
         {
-            gtk_entry_set_text (GTK_ENTRY (entry), file_tag->artist);
+            g_simple_async_report_gerror_in_idle (NULL,
+                                                  mb5_search_error_callback,
+                                                  thread_data, error);
+            g_list_free (list_keys);
+            return;
         }
-        else
+
+        if (g_cancellable_is_cancelled (cancellable))
         {
-            gtk_statusbar_push (GTK_STATUSBAR (gtk_builder_get_object (builder, "statusbar")),
-                        0, _("Artist of current file is not set"));
+            g_set_error (&error, ET_MB5_SEARCH_ERROR,
+                         ET_MB5_SEARCH_ERROR_CANCELLED,
+                         _("Operation cancelled by user"));
+            g_simple_async_report_gerror_in_idle (NULL,
+                                                  mb5_search_error_callback,
+                                                  thread_data, error);
+            g_list_free (list_keys);
+            return;
+        }
+
+        iter = g_list_next (iter);
+    }
+
+    g_list_free (list_keys);
+    g_simple_async_result_set_op_res_gboolean (res, TRUE);
+}
+
+static void
+bt_selected_find_clicked (GtkWidget *widget, gpointer user_data)
+{
+    GtkListStore *tree_model;
+    GtkTreeSelection *selection;
+    int count;
+    GList *iter_list;
+    GList *l;
+    GHashTable *hash_table;
+    SelectedFindThreadData *thread_data;
+    GtkTreeView *browser_list;
+
+    selection = et_application_window_browser_get_selection (ET_APPLICATION_WINDOW (MainWindow));
+    browser_list = gtk_tree_selection_get_tree_view (selection);       
+    iter_list = NULL;
+    tree_model = GTK_LIST_STORE(gtk_tree_view_get_model(GTK_TREE_VIEW(browser_list)));
+    count = gtk_tree_selection_count_selected_rows(selection);
+
+    if (count > 0)
+    {
+        GList* list_sel_rows;
+
+        list_sel_rows = gtk_tree_selection_get_selected_rows(selection, NULL);
+
+        for (l = list_sel_rows; l != NULL; l = g_list_next (l))
+        {
+            GtkTreeIter iter;
+
+            if (gtk_tree_model_get_iter(GTK_TREE_MODEL(tree_model),
+                                        &iter,
+                                        (GtkTreePath *) l->data))
+            {
+                iter_list = g_list_prepend (iter_list,
+                                            gtk_tree_iter_copy (&iter));
+            }
         }
+
+        g_list_free_full (list_sel_rows,
+                          (GDestroyNotify)gtk_tree_path_free);
+
     }
-    else if (type == MB_ENTITY_KIND_ALBUM)
+    else /* No rows selected, use the whole list */
     {
-        if (file_tag->album && *(file_tag->album))
+        GtkTreeIter current_iter;
+
+        if (!gtk_tree_model_get_iter_first(GTK_TREE_MODEL(tree_model),
+                                           &current_iter))
         {
-            gtk_entry_set_text (GTK_ENTRY (entry), file_tag->album);
+            /* No row is present, return */
+            return;
         }
-        else
+
+        do
         {
-            gtk_statusbar_push (GTK_STATUSBAR (gtk_builder_get_object (builder, "statusbar")),
-                        0, _("Album of current file is not set"));
+            iter_list = g_list_prepend (iter_list,
+                                        gtk_tree_iter_copy (&current_iter));
         }
+        while (gtk_tree_model_iter_next(GTK_TREE_MODEL(tree_model),
+               &current_iter));
+
+        count = gtk_tree_model_iter_n_children(GTK_TREE_MODEL(tree_model),
+                                               NULL);
     }
-    else if (type == MB_ENTITY_KIND_TRACK)
+
+    hash_table = g_hash_table_new (g_str_hash,
+                                   g_str_equal);
+
+    for (l = iter_list; l != NULL; l = g_list_next (l))
     {
-        if (file_tag->title && *(file_tag->title))
+        ET_File *etfile;
+        File_Tag *file_tag;
+
+        etfile = et_application_window_browser_get_et_file_from_iter (ET_APPLICATION_WINDOW (MainWindow),
+                                                                      (GtkTreeIter *)l->data);
+        file_tag = (File_Tag *)etfile->FileTag->data;
+
+        if (file_tag->album != NULL)
         {
-            gtk_entry_set_text (GTK_ENTRY (entry), file_tag->title);
-        }
-        else
-        {
-            gtk_statusbar_push (GTK_STATUSBAR (gtk_builder_get_object (builder, "statusbar")),
-                        0, _("Track of current file is not set"));
+            g_hash_table_add (hash_table, file_tag->album);
         }
     }
 
-    btn_manual_find_clicked (NULL, NULL);
+    g_list_free_full (iter_list, (GDestroyNotify)gtk_tree_iter_free);
+    thread_data = g_malloc (sizeof (SelectedFindThreadData));
+    thread_data->hash_table = hash_table;
+    mb5_search_cancellable = g_cancellable_new ();
+    mb_dialog_priv->async_result = g_simple_async_result_new (NULL,
+                                                              selected_find_callback,
+                                                              thread_data,
+                                                              bt_selected_find_clicked);
+    g_simple_async_result_run_in_thread (mb_dialog_priv->async_result,
+                                         selected_find_thread_func, 0,
+                                         mb5_search_cancellable);
+    gtk_statusbar_push (GTK_STATUSBAR (gtk_builder_get_object (builder, "statusbar")),
+                        0, _("Starting Selected Files Search"));
+    et_music_brainz_dialog_stop_set_sensitive (TRUE);
 }
 
 static void


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