[easytag/wip/musicbrainz-support-appwin-merge: 20/78] Made libmusicbrainz optional and added Close button
- From: Abhinav Jangda <abhijangda src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [easytag/wip/musicbrainz-support-appwin-merge: 20/78] Made libmusicbrainz optional and added Close button
- Date: Fri, 22 Aug 2014 13:21:52 +0000 (UTC)
commit 2fec6d5e893bb6cfb0e08ac26c7b289d570d64dd
Author: Abhinav <abhijangda hotmail com>
Date: Fri Aug 22 17:55:54 2014 +0530
Made libmusicbrainz optional and added Close button
Made libmusicbrainz support optional in confiure.ac
Added Close Button
configure.ac | 13 +++++++-
data/musicbrainz_dialog.ui | 26 +++++++++-------
src/mb_search.c | 5 +++
src/mb_search.h | 5 +++
src/mbentityview.c | 18 +++--------
src/mbentityview.h | 7 ++++-
src/musicbrainz_dialog.c | 72 +++++++++++++++++++++++++-------------------
src/musicbrainz_dialog.h | 7 ++++-
8 files changed, 95 insertions(+), 58 deletions(-)
---
diff --git a/configure.ac b/configure.ac
index 07ae230..792791d 100644
--- a/configure.ac
+++ b/configure.ac
@@ -154,7 +154,8 @@ AC_ARG_ENABLE([wavpack],
AC_ARG_ENABLE([nautilus_actions],
[AS_HELP_STRING([--disable-nautilus-actions], [do not build the nautilus context menu actions
(default=auto)])])
-
+AC_ARG_ENABLE([libmusicbrainz],
+ [AS_HELP_STRING([--disable-libmusicbrainz], [Disable support for libmusicbrainz
(default=auto)])])
dnl -------------------------------
dnl Checks for libraries.
@@ -166,6 +167,15 @@ GTK_DEPRECATION_FLAGS="-DGDK_VERSION_MIN_REQUIRED=GDK_VERSION_3_4 -DGDK_VERSION_
dnl libmusicbrainz5
libmusicbrainz_DEPS="libmusicbrainz5 >= 5.0"
+AS_IF([test "x$enable_libmusicbrainz" != "xno"],
+ [PKG_CHECK_EXISTS([$libmusicbrainz_DEPS], [have_libmusicbrainz=yes], [have_libmusicbrainz=no])],
+ [have_libmusicbrainz=no])
+
+AS_IF([test "x$have_libmusicbrainz" != "xno"],
+ [AC_DEFINE([ENABLE_libmusicbrainz], [], [Define for libmusicbrainz support])],
+ [libmusicbrainz_DEPS=""
+ AS_IF([test "x$enable_libmusicbrainz" = "xyes"],
+ [AC_MSG_ERROR([libmusicbrainz support requested but required dependencies
($libmusicbrainz_DEPS) not found])])])
dnl Patch from Ben Taylor to fix a Solaris bug (for CDDB)
AC_CHECK_LIB([socket], [recv])
@@ -443,6 +453,7 @@ echo Ogg Opus file support ...: $have_opus
echo FLAC file support .......: $have_flac
echo MP4 file support ........: $have_taglib
echo WavPack support .........: $have_wavpack
+echo MusicBrainz support .....: $have_libmusicbrainz
echo NLS/gettext .............: $USE_NLS
echo Nautilus actions ........: $have_libnautilus_extension
echo Tests during make check .: $testing_utilities
diff --git a/data/musicbrainz_dialog.ui b/data/musicbrainz_dialog.ui
index ed2a2fe..7531e14 100755
--- a/data/musicbrainz_dialog.ui
+++ b/data/musicbrainz_dialog.ui
@@ -1,6 +1,16 @@
<?xml version="1.0" encoding="UTF-8"?>
<interface>
<!-- interface-requires gtk+ 3.0 -->
+ <object class="GtkImage" id="findimage">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="stock">gtk-find</property>
+ </object>
+ <object class="GtkImage" id="img_invert_selection">
+ <property name="visible">True</property>
+ <property name="can_focus">False</property>
+ <property name="stock">easytag-invert-selection</property>
+ </object>
<object class="GtkImage" id="img_red_lines">
<property name="visible">True</property>
<property name="can_focus">False</property>
@@ -11,11 +21,6 @@
<property name="can_focus">False</property>
<property name="stock">easytag-unselect-all</property>
</object>
- <object class="GtkImage" id="findimage">
- <property name="visible">True</property>
- <property name="can_focus">False</property>
- <property name="stock">gtk-find</property>
- </object>
<object class="GtkImage" id="image10">
<property name="visible">True</property>
<property name="can_focus">False</property>
@@ -52,11 +57,6 @@
<property name="can_focus">False</property>
<property name="stock">gtk-stop</property>
</object>
- <object class="GtkImage" id="img_invert_selection">
- <property name="visible">True</property>
- <property name="can_focus">False</property>
- <property name="stock">easytag-invert-selection</property>
- </object>
<object class="GtkDialog" id="mbDialog">
<property name="can_focus">False</property>
<property name="border_width">5</property>
@@ -156,6 +156,7 @@
<child>
<object class="GtkButton" id="btnAutomaticStop">
<property name="visible">True</property>
+ <property name="sensitive">False</property>
<property name="can_focus">True</property>
<property name="receives_default">True</property>
<property name="image">image9</property>
@@ -300,6 +301,7 @@
<child>
<object class="GtkButton" id="btnManualStop">
<property name="visible">True</property>
+ <property name="sensitive">False</property>
<property name="can_focus">True</property>
<property name="receives_default">True</property>
<property name="tooltip_text" translatable="yes">Stop Manual
Search</property>
@@ -377,6 +379,7 @@
<child>
<object class="GtkButton" id="btnSelectedStop">
<property name="visible">True</property>
+ <property name="sensitive">False</property>
<property name="can_focus">True</property>
<property name="receives_default">True</property>
<property name="image">image11</property>
@@ -453,6 +456,7 @@
<child>
<object class="GtkButton" id="btnDiscStop">
<property name="visible">True</property>
+ <property name="sensitive">False</property>
<property name="can_focus">True</property>
<property name="receives_default">True</property>
<property name="image">image13</property>
@@ -699,7 +703,7 @@
<property name="can_focus">False</property>
<property name="spacing">4</property>
<child>
- <object class="GtkButton" id="button9">
+ <object class="GtkButton" id="btnClose">
<property name="label" translatable="yes">Close</property>
<property name="visible">True</property>
<property name="can_focus">True</property>
diff --git a/src/mb_search.c b/src/mb_search.c
index acbfa1e..ecf1b10 100755
--- a/src/mb_search.c
+++ b/src/mb_search.c
@@ -18,6 +18,10 @@
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
+#include "config.h"
+
+#ifdef ENABLE_libmusicbrainz
+
#include <glib/gi18n.h>
#include "mb_search.h"
@@ -783,3 +787,4 @@ free_mb_tree (GNode *node)
g_node_destroy (node);
}
+#endif /* ENABLE_libmusicbrainz */
diff --git a/src/mb_search.h b/src/mb_search.h
index d4009f2..0d4e96c 100755
--- a/src/mb_search.h
+++ b/src/mb_search.h
@@ -21,6 +21,10 @@
#ifndef __MB_SEARCH_H__
#define __MB_SEARCH_H__
+#include "config.h"
+
+#ifdef ENABLE_libmusicbrainz
+
#include <gtk/gtk.h>
#include <musicbrainz5/mb5_c.h>
@@ -101,3 +105,4 @@ free_mb_tree (GNode *node);
void
et_set_cancel_error (GError **error);
#endif /* __MB_SEARCH_H__ */
+#endif /* ENABLE_libmusicbrainz */
diff --git a/src/mbentityview.c b/src/mbentityview.c
index 4facd26..6113135 100644
--- a/src/mbentityview.c
+++ b/src/mbentityview.c
@@ -18,6 +18,10 @@
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
+#include "config.h"
+
+#ifdef ENABLE_libmusicbrainz
+
#include <gdk/gdkkeysyms.h>
#include <glib/gi18n.h>
@@ -1154,19 +1158,7 @@ et_mb_entity_view_finalize (GObject *object)
entity_view = ET_MB_ENTITY_VIEW (object);
priv = ET_MB_ENTITY_VIEW_GET_PRIVATE (entity_view);
-<<<<<<< HEAD
-
- if (GTK_IS_LIST_STORE (priv->list_store))
- {
- g_object_unref (priv->list_store);
- }
-
- if (GTK_WIDGET_CLASS (et_mb_entity_view_parent_class)->destroy)
- {
- (*GTK_WIDGET_CLASS (et_mb_entity_view_parent_class)->destroy)(object);
- }
-=======
g_clear_object (&priv->list_store);
G_OBJECT_CLASS (et_mb_entity_view_parent_class)->finalize(object);
->>>>>>> 4b51406... Some Improvements after review
}
+#endif /* ENABLE_libmusicbrainz */
diff --git a/src/mbentityview.h b/src/mbentityview.h
index 8f63f3d..a57596e 100755
--- a/src/mbentityview.h
+++ b/src/mbentityview.h
@@ -21,6 +21,10 @@
#ifndef __MB_ENTITY_VIEW_H__
#define __MB_ENTITY_VIEW_H__
+#include "config.h"
+
+#ifdef ENABLE_libmusicbrainz
+
G_BEGIN_DECLS
#include <gtk/gtk.h>
@@ -126,4 +130,5 @@ void
et_mb_entity_view_clear_all (EtMbEntityView *entity_view);
G_END_DECLS
-#endif /* __MB_ENTITY_VIEW_H__ */
\ No newline at end of file
+#endif /* __MB_ENTITY_VIEW_H__ */
+#endif /* ENABLE_libmusicbrainz */
\ No newline at end of file
diff --git a/src/musicbrainz_dialog.c b/src/musicbrainz_dialog.c
index a0917a1..fb76ab7 100755
--- a/src/musicbrainz_dialog.c
+++ b/src/musicbrainz_dialog.c
@@ -20,6 +20,8 @@
#include "config.h"
+#ifdef ENABLE_libmusicbrainz
+
#include <gtk/gtk.h>
#include <gdk/gdkkeysyms.h>
#include <glib/gi18n.h>
@@ -36,15 +38,15 @@
/***************
* Declaration *
***************/
-
-static GNode *mb_tree_root;
-static GSimpleAsyncResult *async_result;
+//static GSimpleAsyncResult *async_result;
typedef struct
{
GNode *mb_tree_root;
GSimpleAsyncResult *async_result;
-} MusicBrainzDialog;
+} MusicBrainzDialogPrivate;
+
+static MusicBrainzDialogPrivate *mb_dialog_priv;
typedef struct
{
@@ -85,13 +87,13 @@ manual_search_callback (GObject *source, GAsyncResult *res,
{
g_object_unref (res);
g_free (user_data);
- free_mb_tree (mb_tree_root);
- mb_tree_root = g_node_new (NULL);
+ free_mb_tree (mb_dialog_priv->mb_tree_root);
+ mb_dialog_priv->mb_tree_root = g_node_new (NULL);
return;
}
et_mb_entity_view_set_tree_root (ET_MB_ENTITY_VIEW (entityView),
- mb_tree_root);
+ mb_dialog_priv->mb_tree_root);
gtk_statusbar_push (GTK_STATUSBAR (gtk_builder_get_object (builder,
"statusbar")), 0, _("Searching Completed"));
g_object_unref (res);
@@ -211,7 +213,7 @@ manual_search_thread_func (GSimpleAsyncResult *res, GObject *obj,
}
if (!et_musicbrainz_search (thread_data->text_to_search,
- thread_data->type, mb_tree_root, &error,
+ thread_data->type, mb_dialog_priv->mb_tree_root, &error,
cancellable))
{
g_simple_async_report_gerror_in_idle (NULL,
@@ -258,10 +260,10 @@ btn_manual_find_clicked (GtkWidget *btn, gpointer user_data)
return;
}
- if (g_node_first_child (mb_tree_root))
+ if (g_node_first_child (mb_dialog_priv->mb_tree_root))
{
- free_mb_tree (mb_tree_root);
- mb_tree_root = g_node_new (NULL);
+ free_mb_tree (mb_dialog_priv->mb_tree_root);
+ mb_dialog_priv->mb_tree_root = g_node_new (NULL);
}
et_mb_entity_view_clear_all (ET_MB_ENTITY_VIEW (entityView));
@@ -273,10 +275,10 @@ btn_manual_find_clicked (GtkWidget *btn, gpointer user_data)
mb5_search_cancellable = g_cancellable_new ();
gtk_statusbar_push (GTK_STATUSBAR (gtk_builder_get_object (builder,
"statusbar")), 0, _("Starting MusicBrainz Search"));
- async_result = g_simple_async_result_new (NULL, manual_search_callback,
+ mb_dialog_priv->async_result = g_simple_async_result_new (NULL, manual_search_callback,
thread_data,
btn_manual_find_clicked);
- g_simple_async_result_run_in_thread (async_result,
+ g_simple_async_result_run_in_thread (mb_dialog_priv->async_result,
manual_search_thread_func, 0,
mb5_search_cancellable);
}
@@ -419,13 +421,13 @@ selected_find_callback (GObject *source, GAsyncResult *res,
g_object_unref (res);
g_object_unref (((SelectedFindThreadData *)user_data)->hash_table);
g_free (user_data);
- free_mb_tree (mb_tree_root);
- mb_tree_root = g_node_new (NULL);
+ free_mb_tree (mb_dialog_priv->mb_tree_root);
+ mb_dialog_priv->mb_tree_root = g_node_new (NULL);
return;
}
et_mb_entity_view_set_tree_root (ET_MB_ENTITY_VIEW (entityView),
- mb_tree_root);
+ mb_dialog_priv->mb_tree_root);
gtk_statusbar_push (GTK_STATUSBAR (gtk_builder_get_object (builder, "statusbar")),
0, _("Searching Completed"));
g_object_unref (res);
@@ -451,7 +453,7 @@ selected_find_thread_func (GSimpleAsyncResult *res, GObject *obj,
while (iter)
{
if (!et_musicbrainz_search ((gchar *)iter->data, MB_ENTITY_KIND_ALBUM,
- mb_tree_root, &error, cancellable))
+ mb_dialog_priv->mb_tree_root, &error, cancellable))
{
g_simple_async_report_gerror_in_idle (NULL,
mb5_search_error_callback,
@@ -560,10 +562,11 @@ bt_selected_find_clicked (GtkWidget *widget, gpointer user_data)
thread_data = g_malloc (sizeof (SelectedFindThreadData));
thread_data->hash_table = hash_table;
mb5_search_cancellable = g_cancellable_new ();
- async_result = g_simple_async_result_new (NULL, selected_find_callback,
- thread_data,
- bt_selected_find_clicked);
- g_simple_async_result_run_in_thread (async_result,
+ 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")),
@@ -577,13 +580,13 @@ discid_search_callback (GObject *source, GAsyncResult *res,
if (!g_simple_async_result_get_op_res_gboolean (G_SIMPLE_ASYNC_RESULT (res)))
{
g_object_unref (res);
- free_mb_tree (mb_tree_root);
- mb_tree_root = g_node_new (NULL);
+ free_mb_tree (mb_dialog_priv->mb_tree_root);
+ mb_dialog_priv->mb_tree_root = g_node_new (NULL);
return;
}
et_mb_entity_view_set_tree_root (ET_MB_ENTITY_VIEW (entityView),
- mb_tree_root);
+ mb_dialog_priv->mb_tree_root);
gtk_statusbar_push (GTK_STATUSBAR (gtk_builder_get_object (builder, "statusbar")),
0, _("Searching Completed"));
g_object_unref (res);
@@ -629,7 +632,7 @@ discid_search_thread_func (GSimpleAsyncResult *res, GObject *obj,
return;
}
- if (!et_musicbrainz_search (discid, MB_ENTITY_KIND_DISCID, mb_tree_root,
+ if (!et_musicbrainz_search (discid, MB_ENTITY_KIND_DISCID, mb_dialog_priv->mb_tree_root,
&error, cancellable))
{
g_simple_async_report_gerror_in_idle (NULL,
@@ -640,7 +643,7 @@ discid_search_thread_func (GSimpleAsyncResult *res, GObject *obj,
}
et_mb_entity_view_set_tree_root (ET_MB_ENTITY_VIEW (entityView),
- mb_tree_root);
+ mb_dialog_priv->mb_tree_root);
discid_free (disc);
g_simple_async_result_set_op_res_gboolean (G_SIMPLE_ASYNC_RESULT (res),
TRUE);
@@ -652,10 +655,10 @@ btn_discid_search (GtkWidget *button, gpointer data)
mb5_search_cancellable = g_cancellable_new ();
gtk_statusbar_push (GTK_STATUSBAR (gtk_builder_get_object (builder, "statusbar")),
0, _("Starting MusicBrainz Search"));
- async_result = g_simple_async_result_new (NULL, discid_search_callback,
+ mb_dialog_priv->async_result = g_simple_async_result_new (NULL, discid_search_callback,
NULL,
btn_manual_find_clicked);
- g_simple_async_result_run_in_thread (async_result,
+ g_simple_async_result_run_in_thread (mb_dialog_priv->async_result,
discid_search_thread_func, 0,
mb5_search_cancellable);
}
@@ -663,7 +666,10 @@ btn_discid_search (GtkWidget *button, gpointer data)
static void
btn_close_clicked (GtkWidget *button, gpointer data)
{
- gtk_dialog_response (GTK_DIALOG (mbDialog), GTK_RESPONSE_CLOSE);
+ gtk_widget_destroy (mbDialog);
+ g_object_unref (G_OBJECT (builder));
+ free_mb_tree (mb_dialog_priv->mb_tree_root);
+ g_free (mb_dialog_priv);
}
/*
@@ -692,12 +698,14 @@ et_open_musicbrainz_dialog ()
return;
}
- mb_tree_root = g_node_new (NULL);
+ mb_dialog_priv = g_malloc (sizeof (MusicBrainzDialogPrivate));
+ mb_dialog_priv->mb_tree_root = g_node_new (NULL);
entityView = et_mb_entity_view_new ();
mbDialog = GTK_WIDGET (gtk_builder_get_object (builder, "mbDialog"));
gtk_widget_set_size_request (mbDialog, 600, 500);
gtk_box_pack_start (GTK_BOX (gtk_builder_get_object (builder, "centralBox")),
entityView, TRUE, TRUE, 2);
+
g_signal_connect (gtk_builder_get_object (builder, "btnManualFind"),
"clicked", G_CALLBACK (btn_manual_find_clicked),
NULL);
@@ -759,5 +767,7 @@ et_open_musicbrainz_dialog ()
gtk_dialog_run (GTK_DIALOG (mbDialog));
gtk_widget_destroy (mbDialog);
g_object_unref (G_OBJECT (builder));
- free_mb_tree (mb_tree_root);
+ free_mb_tree (mb_dialog_priv->mb_tree_root);
+ g_free (mb_dialog_priv);
}
+#endif /* ENABLE_libmusicbrainz */
diff --git a/src/musicbrainz_dialog.h b/src/musicbrainz_dialog.h
index ed5f02f..901063e 100755
--- a/src/musicbrainz_dialog.h
+++ b/src/musicbrainz_dialog.h
@@ -21,6 +21,10 @@
#ifndef __MUSICBRAINZ_DIALOG_H__
#define __MUSICBRAINZ_DIALOG_H__
+#include "config.h"
+
+#ifdef ENABLE_libmusicbrainz
+
/****************
* Declarations *
****************/
@@ -40,4 +44,5 @@ mb5_search_error_callback (GObject *source, GAsyncResult *res,
gpointer user_data);
void
et_show_status_msg_in_idle (gchar *message);
-#endif /* __MUSICBRAINZ_DIALOG_H__ */
\ No newline at end of file
+#endif /* __MUSICBRAINZ_DIALOG_H__ */
+#endif /* ENABLE_libmusicbrainz */
\ No newline at end of file
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]