diff options
-rw-r--r-- | audio/goobox/Makefile | 18 | ||||
-rw-r--r-- | audio/goobox/distinfo | 4 | ||||
-rw-r--r-- | audio/goobox/files/patch-port_to_libmusicbrainz3 | 773 | ||||
-rw-r--r-- | audio/goobox/files/patch-port_to_libnotify07 | 26 | ||||
-rw-r--r-- | audio/goobox/files/patch-src_cd-drive.c | 12 | ||||
-rw-r--r-- | audio/goobox/files/patch-src_main.c | 11 | ||||
-rw-r--r-- | audio/goobox/pkg-plist | 47 |
7 files changed, 845 insertions, 46 deletions
diff --git a/audio/goobox/Makefile b/audio/goobox/Makefile index b72f9fa01e2e..f9d982562e0b 100644 --- a/audio/goobox/Makefile +++ b/audio/goobox/Makefile @@ -7,8 +7,7 @@ # PORTNAME= goobox -PORTVERSION= 1.9.2 -PORTREVISION= 7 +PORTVERSION= 2.2.0 CATEGORIES= audio gnome MASTER_SITES= GNOME DIST_SUBDIR= gnome2 @@ -16,15 +15,19 @@ DIST_SUBDIR= gnome2 MAINTAINER= gnome@FreeBSD.org COMMENT= CD player and ripper for GNOME Desktop environment -LIB_DEPENDS= musicbrainz.4:${PORTSDIR}/audio/libmusicbrainz +BUILD_DEPENDS= ${LOCALBASE}/share/icons/gnome/index.theme:${PORTSDIR}/misc/gnome-icon-theme +LIB_DEPENDS= discid.0:${PORTSDIR}/audio/libdiscid \ + musicbrainz3.6:${PORTSDIR}/audio/libmusicbrainz3 \ + brasero-media.3:${PORTSDIR}/sysutils/brasero \ + unique-1.0.2:${PORTSDIR}/x11-toolkits/unique +RUN_DEPENDS= ${LOCALBASE}/share/icons/gnome/index.theme:${PORTSDIR}/misc/gnome-icon-theme USE_XORG= x11 USE_GETTEXT= yes USE_BZIP2= yes USE_GMAKE= yes -USE_GNOME= gnomeprefix gnomehack intlhack libgnomeui libglade2 libbonobo \ - gnomedocutils nautiluscdburner -USE_GSTREAMER= cdparanoia gconf core +USE_GNOME= gnomeprefix gnomehack intlhack gtk20 gconf2 desktopfileutils +USE_GSTREAMER= cdparanoia gconf core gio GNU_CONFIGURE= yes INSTALLS_OMF= yes INSTALLS_ICONS= yes @@ -44,4 +47,7 @@ CONFIGURE_ARGS+= --enable-notification CONFIGURE_ARGS+= --disable-notification .endif +post-install: + @-update-desktop-database + .include <bsd.port.post.mk> diff --git a/audio/goobox/distinfo b/audio/goobox/distinfo index 759f59d29f3e..bda18b5d18e4 100644 --- a/audio/goobox/distinfo +++ b/audio/goobox/distinfo @@ -1,2 +1,2 @@ -SHA256 (gnome2/goobox-1.9.2.tar.bz2) = 09c025e6deab5101b23cfdcbea8a1e883e15d59bfb4c3a2888c101c7882408c5 -SIZE (gnome2/goobox-1.9.2.tar.bz2) = 553022 +SHA256 (gnome2/goobox-2.2.0.tar.bz2) = d18e343c7621b56cb7bb1925a61c9b78f8aa25bbdbddff40378d7df00950b53a +SIZE (gnome2/goobox-2.2.0.tar.bz2) = 576966 diff --git a/audio/goobox/files/patch-port_to_libmusicbrainz3 b/audio/goobox/files/patch-port_to_libmusicbrainz3 new file mode 100644 index 000000000000..f6ac31597963 --- /dev/null +++ b/audio/goobox/files/patch-port_to_libmusicbrainz3 @@ -0,0 +1,773 @@ +--- configure.orig 2012-03-14 12:11:24.000000000 -0500 ++++ configure 2012-03-14 13:33:57.000000000 -0500 +@@ -14820,7 +14820,7 @@ + GTK_REQUIRED=2.18 + GSTREAMER_REQUIRED=0.10.12 + LIBNOTIFY_REQUIRED=0.4.3 +-LIBMUSICBRAINZ_REQUIRED=2.1.0 ++LIBMUSICBRAINZ3_REQUIRED=3.0.0 + + + +@@ -14932,7 +14932,8 @@ + gtk+-2.0 >= \$GTK_REQUIRED + gstreamer-0.10 >= \$GSTREAMER_REQUIRED + libbrasero-media +- libmusicbrainz >= \$LIBMUSICBRAINZ_REQUIRED ++ libmusicbrainz3 >= \$LIBMUSICBRAINZ3_REQUIRED ++ libdiscid + gconf-2.0 + unique-1.0 + \""; } >&5 +@@ -14942,7 +14943,8 @@ + gtk+-2.0 >= $GTK_REQUIRED + gstreamer-0.10 >= $GSTREAMER_REQUIRED + libbrasero-media +- libmusicbrainz >= $LIBMUSICBRAINZ_REQUIRED ++ libmusicbrainz3 >= $LIBMUSICBRAINZ3_REQUIRED ++ libdiscid + gconf-2.0 + unique-1.0 + ") 2>&5 +@@ -14955,7 +14957,8 @@ + gtk+-2.0 >= $GTK_REQUIRED + gstreamer-0.10 >= $GSTREAMER_REQUIRED + libbrasero-media +- libmusicbrainz >= $LIBMUSICBRAINZ_REQUIRED ++ libmusicbrainz3 >= $LIBMUSICBRAINZ3_REQUIRED ++ libdiscid + gconf-2.0 + unique-1.0 + " 2>/dev/null` +@@ -14977,7 +14980,8 @@ + gtk+-2.0 >= \$GTK_REQUIRED + gstreamer-0.10 >= \$GSTREAMER_REQUIRED + libbrasero-media +- libmusicbrainz >= \$LIBMUSICBRAINZ_REQUIRED ++ libmusicbrainz3 >= \$LIBMUSICBRAINZ3_REQUIRED ++ libdiscid + gconf-2.0 + unique-1.0 + \""; } >&5 +@@ -14987,7 +14991,8 @@ + gtk+-2.0 >= $GTK_REQUIRED + gstreamer-0.10 >= $GSTREAMER_REQUIRED + libbrasero-media +- libmusicbrainz >= $LIBMUSICBRAINZ_REQUIRED ++ libmusicbrainz3 >= $LIBMUSICBRAINZ3_REQUIRED ++ libdiscid + gconf-2.0 + unique-1.0 + ") 2>&5 +@@ -15000,7 +15005,8 @@ + gtk+-2.0 >= $GTK_REQUIRED + gstreamer-0.10 >= $GSTREAMER_REQUIRED + libbrasero-media +- libmusicbrainz >= $LIBMUSICBRAINZ_REQUIRED ++ libmusicbrainz3 >= $LIBMUSICBRAINZ3_REQUIRED ++ libdiscid + gconf-2.0 + unique-1.0 + " 2>/dev/null` +@@ -15028,7 +15034,8 @@ + gtk+-2.0 >= $GTK_REQUIRED + gstreamer-0.10 >= $GSTREAMER_REQUIRED + libbrasero-media +- libmusicbrainz >= $LIBMUSICBRAINZ_REQUIRED ++ libmusicbrainz3 >= $LIBMUSICBRAINZ3_REQUIRED ++ libdiscid + gconf-2.0 + unique-1.0 + "` +@@ -15039,7 +15046,8 @@ + gtk+-2.0 >= $GTK_REQUIRED + gstreamer-0.10 >= $GSTREAMER_REQUIRED + libbrasero-media +- libmusicbrainz >= $LIBMUSICBRAINZ_REQUIRED ++ libmusicbrainz3 >= $LIBMUSICBRAINZ3_REQUIRED ++ libdiscid + gconf-2.0 + unique-1.0 + "` +@@ -15053,7 +15061,8 @@ + gtk+-2.0 >= $GTK_REQUIRED + gstreamer-0.10 >= $GSTREAMER_REQUIRED + libbrasero-media +- libmusicbrainz >= $LIBMUSICBRAINZ_REQUIRED ++ libmusicbrainz3 >= $LIBMUSICBRAINZ3_REQUIRED ++ libdiscid + gconf-2.0 + unique-1.0 + ) were not met: +diff --git a/data/ui/properties.ui b/data/ui/properties.ui +index b28d921..83aaf21 100644 +--- data/ui/properties.ui ++++ data/ui/properties.ui +@@ -344,7 +344,7 @@ + <property name="can_focus">False</property> + <property name="spacing">6</property> + <child> +- <object class="GtkImage" id="image2"> ++ <object class="GtkImage" id="info_icon"> + <property name="visible">True</property> + <property name="can_focus">False</property> + <property name="stock">gtk-dialog-warning</property> +diff --git a/src/album-info.c b/src/album-info.c +index 10c3bc8..7effa35 100644 +--- src/album-info.c ++++ src/album-info.c +@@ -26,6 +26,7 @@ + #include "album-info.h" + #include "glib-utils.h" + #include "gth-user-dir.h" ++#include "track-info.h" + + + #define MBI_VARIOUS_ARTIST_ID "89ad4ac3-39f7-470e-963a-56509c546377" +@ -226,18 +227,21 @@ album_info_set_tracks (AlbumInfo *album, + GList *tracks) + { + GList *scan; +- ++ + if (album->tracks == tracks) + return; +- ++ + track_list_free (album->tracks); + album->tracks = track_list_dup (tracks); +- ++ + album->n_tracks = 0; + album->total_length = 0; + for (scan = album->tracks; scan; scan = scan->next) { + TrackInfo *track = scan->data; +- ++ ++ if ((album->artist != NULL) && (track->artist == NULL)) ++ track_info_set_artist (track, album->artist, album->artist_id); ++ + album->n_tracks++; + album->total_length += track->length; + } +diff --git a/src/dlg-properties.c b/src/dlg-properties.c +index de56ecd..7cf0d2a 100644 +--- src/dlg-properties.c ++++ src/dlg-properties.c +@@ -218,49 +218,54 @@ remove_incompatible_albums (GList *albums, + else + scan = scan->next; + } +- ++ + return albums; + } + + + static void +-search_cb (GtkWidget *widget, ++search_cb (GtkWidget *widget, + DialogData *data) + { +- musicbrainz_t mb; +- char *mb_args[2]; +- +- mb = mb_New (); +- mb_UseUTF8 (mb, TRUE); +- mb_SetDepth (mb, 4); +- /*mb_SetMaxItems(mb, 10);*/ +- +- mb_args[0] = (char*) gtk_entry_get_text (GTK_ENTRY (GET_WIDGET ("title_entry"))); +- mb_args[1] = NULL; +- if (! mb_QueryWithArgs (mb, MBQ_FindAlbumByName, mb_args)) { +- char mb_error[1024]; +- char *s; +- +- mb_GetQueryError (mb, mb_error, sizeof (mb_error)); +- s = g_strdup_printf (_("Search failed: %s\n"), mb_error); +- gtk_label_set_text (GTK_LABEL (GET_WIDGET ("info_label")), s); +- g_free (s); +- } +- else { +- data->albums = get_album_list (mb); +- data->albums = remove_incompatible_albums (data->albums, goo_window_get_album (data->window)); +- data->n_albums = g_list_length (data->albums); +- +- if (data->n_albums == 0) { +- gtk_label_set_text (GTK_LABEL (GET_WIDGET ("info_label")), _("No album found")); +- gtk_widget_show (GET_WIDGET ("info_box")); +- gtk_widget_hide (GET_WIDGET ("navigation_box")); +- } +- else +- show_album (data, 0); ++ MbReleaseFilter filter; ++ MbQuery query; ++ MbResultList list; ++ ++ gtk_image_set_from_stock (GTK_IMAGE (GET_WIDGET ("info_icon")), GTK_STOCK_FIND, GTK_ICON_SIZE_BUTTON); ++ gtk_label_set_text (GTK_LABEL (GET_WIDGET ("info_label")), _("Searching disc info...")); ++ gtk_widget_show (GET_WIDGET ("info_box")); ++ gtk_widget_hide (GET_WIDGET ("navigation_box")); ++ ++ /* ++ metadata_search_album_by_title (gtk_entry_get_text (GTK_ENTRY (GET_WIDGET ("title_entry"))), ++ data->cancellable, ++ G_CALLBACK (search_album_by_title_ready_cb), ++ data); ++ */ ++ ++ filter = mb_release_filter_new (); ++ mb_release_filter_title (filter, gtk_entry_get_text (GTK_ENTRY (GET_WIDGET ("title_entry")))); ++ ++ query = mb_query_new (NULL, NULL); ++ list = mb_query_get_releases (query, filter); ++ ++ data->albums = get_album_list (list); ++ get_track_info_for_album_list (data->albums); ++ data->albums = remove_incompatible_albums (data->albums, goo_window_get_album (data->window)); ++ data->n_albums = g_list_length (data->albums); ++ ++ if (data->n_albums == 0) { ++ gtk_image_set_from_stock (GTK_IMAGE (GET_WIDGET ("info_icon")), GTK_STOCK_DIALOG_WARNING, GTK_ICON_SIZE_BUTTON); ++ gtk_label_set_text (GTK_LABEL (GET_WIDGET ("info_label")), _("No album found")); ++ gtk_widget_show (GET_WIDGET ("info_box")); ++ gtk_widget_hide (GET_WIDGET ("navigation_box")); + } ++ else ++ show_album (data, 0); + +- mb_Delete (mb); ++ mb_result_list_free (list); ++ mb_query_free (query); ++ mb_release_filter_free (filter); + } + + +diff --git a/src/goo-player.c b/src/goo-player.c +index 050d1d2..6de4a9a 100644 +--- src/goo-player.c ++++ src/goo-player.c +@@ -25,8 +25,8 @@ + #include <string.h> + #include <glib/gi18n.h> + #include <gst/gst.h> +-#include <musicbrainz/queries.h> +-#include <musicbrainz/mb_c.h> ++#include <discid/discid.h> ++#include <musicbrainz3/mb_c.h> + #include "goo-player.h" + #include "goo-marshal.h" + #include "glib-utils.h" +@@ -74,6 +74,7 @@ + gboolean exiting; + + char *rdf; ++ GList *albums; + }; + + enum { +@@ -348,6 +349,7 @@ + self->priv->current_track_n = -1; + self->priv->volume_value = 1.0; + self->priv->update_progress_id = 0; ++ self->priv->albums = NULL; + } + + +@@ -457,6 +459,9 @@ + } + + ++#if 0 ++ ++ + static void + set_cd_metadata_from_rdf (GooPlayer *self, + char *rdf) +@@ -552,13 +557,16 @@ + } + + ++#endif ++ ++ + static int + check_get_cd_metadata (gpointer data) + { + GooPlayer *player = data; + gboolean done, exiting; +- char *rdf; +- ++ GList *albums; ++ + /* Remove the check. */ + + g_source_remove (player->priv->check_id); +@@ -587,45 +595,51 @@ + /**/ + + g_mutex_lock (player->priv->yes_or_no); +- rdf = player->priv->rdf; +- player->priv->rdf = NULL; ++ albums = player->priv->albums; ++ player->priv->albums = NULL; + g_mutex_unlock (player->priv->yes_or_no); +- +- if (rdf != NULL) { +- set_cd_metadata_from_rdf (player, rdf); +- save_rdf_to_cache (player, rdf); ++ ++ if (albums != NULL) { ++ AlbumInfo *first_album = albums->data; ++ ++ /* FIXME: ask the user which album to use if the query ++ * returned more than one album. */ ++ ++ goo_player_set_album (player, first_album); + album_info_save_to_cache (player->priv->album, player->priv->discid); +- g_free (rdf); ++ ++ album_list_free (albums); + } +- +- return FALSE; ++ ++ return FALSE; + } + + + static void * + get_cd_metadata (void *thread_data) + { +- GooPlayer *player = thread_data; +- musicbrainz_t mb; +- char *rdf = NULL; +- +- mb = mb_New (); +- mb_UseUTF8 (mb, TRUE); +- if (mb_Query (mb, MBQ_GetCDInfo)) { +- int rdf_len; +- +- rdf_len = mb_GetResultRDFLen (mb); +- rdf = g_malloc (rdf_len + 1); +- mb_GetResultRDF (mb, rdf, rdf_len); +- } +- mb_Delete (mb); ++ GooPlayer *player = thread_data; ++ MbReleaseFilter filter; ++ MbQuery query; ++ MbResultList list; ++ ++ filter = mb_release_filter_new (); ++ mb_release_filter_disc_id (filter, player->priv->discid); ++ mb_release_filter_limit (filter, 1); ++ ++ query = mb_query_new (NULL, NULL); ++ list = mb_query_get_releases (query, filter); + + g_mutex_lock (player->priv->yes_or_no); +- g_free (player->priv->rdf); +- player->priv->rdf = rdf; ++ album_list_free (player->priv->albums); ++ player->priv->albums = get_album_list (list); + player->priv->thread = NULL; + g_mutex_unlock (player->priv->yes_or_no); + ++ mb_result_list_free (list); ++ mb_query_free (query); ++ mb_release_filter_free (filter); ++ + g_thread_exit (NULL); + + return NULL; +@@ -638,8 +652,7 @@ + GooPlayer *player = data; + gboolean done; + gboolean exiting; +- char *rdf; +- ++ + /* Remove the check. */ + + g_source_remove (player->priv->check_id); +@@ -680,13 +693,13 @@ + action_done (player, GOO_PLAYER_ACTION_METADATA); + return FALSE; + } +- +- rdf = read_cached_rdf (player); +- if (rdf != NULL) { +- set_cd_metadata_from_rdf (player, rdf); +- g_free (rdf); +- return FALSE; +- } ++ ++ /* ++ metadata_get_album_info_from_disc_id (player->priv->discid, ++ data->cancellable, ++ G_CALLBACK (album_info_from_disc_id_ready_cb), ++ data); ++ */ + + g_mutex_lock (player->priv->yes_or_no); + player->priv->thread = g_thread_create (get_cd_metadata, player, FALSE, NULL); +@@ -701,45 +714,45 @@ + static void * + get_cd_tracks (void *thread_data) + { +- GooPlayer *player = thread_data; +- GList *tracks = NULL; +- musicbrainz_t mb; +- ++ GooPlayer *player = thread_data; ++ GList *tracks = NULL; ++ DiscId *disc; ++ + if (player->priv->pipeline != NULL) + gst_element_set_state (player->priv->pipeline, GST_STATE_PAUSED); + + g_free (player->priv->discid); + player->priv->discid = NULL; + +- mb = mb_New (); +- mb_UseUTF8 (mb, TRUE); +- mb_SetDevice (mb, (char *) goo_player_get_device (player)); +- if (mb_Query (mb, MBQ_GetCDTOC)) { +- char data[256]; +- int n_tracks, i; +- +- mb_GetResultData(mb, MBE_TOCGetCDIndexId, data, sizeof (data)); +- player->priv->discid = g_strdup (data); ++ disc = discid_new (); ++ if (discid_read (disc, goo_player_get_device (player))) { ++ int first_track; ++ int last_track; ++ int i; ++ ++ player->priv->discid = g_strdup (discid_get_id (disc)); + debug (DEBUG_INFO, "==> [MB] DISC ID: %s\n", player->priv->discid); +- +- debug (DEBUG_INFO, "==> [MB] FIRST TRACK: %d\n", mb_GetResultInt (mb, MBE_TOCGetFirstTrack)); +- +- n_tracks = mb_GetResultInt (mb, MBE_TOCGetLastTrack); +- debug (DEBUG_INFO, "==> [MB] LAST TRACK: %d\n", n_tracks); +- +- for (i = 0; i < n_tracks; i++) { ++ ++ first_track = discid_get_first_track_num (disc); ++ debug (DEBUG_INFO, "==> [MB] FIRST TRACK: %d\n", first_track); ++ ++ last_track = discid_get_last_track_num (disc); ++ debug (DEBUG_INFO, "==> [MB] LAST TRACK: %d\n", last_track); ++ ++ for (i = first_track; i <= last_track; i++) { + gint64 from_sector; + gint64 n_sectors; +- +- from_sector = mb_GetResultInt1 (mb, MBE_TOCGetTrackSectorOffset, i + 2); +- n_sectors = mb_GetResultInt1 (mb, MBE_TOCGetTrackNumSectors, i + 2); +- ++ ++ from_sector = discid_get_track_offset (disc, i); ++ n_sectors = discid_get_track_length (disc, i); ++ + debug (DEBUG_INFO, "==> [MB] Track %d: [%"G_GINT64_FORMAT", %"G_GINT64_FORMAT"]\n", i, from_sector, from_sector + n_sectors); +- +- tracks = g_list_prepend (tracks, track_info_new (i, from_sector, from_sector + n_sectors)); ++ ++ tracks = g_list_prepend (tracks, track_info_new (i - first_track, from_sector, from_sector + n_sectors)); + } + } +- mb_Delete (mb); ++ ++ discid_free (disc); + + tracks = g_list_reverse (tracks); + album_info_set_tracks (player->priv->album, tracks); +@@ -821,7 +834,14 @@ + goo_player_empty_list (player); + goo_player_set_is_busy (player, TRUE); + create_pipeline (player); +- ++ ++ /* FIXME ++ metadata_read_cd_info_from_device (goo_player_get_device (player), ++ data->cancellable, ++ G_CALLBACK (cd_info_from_device_ready_cb), ++ data); ++ */ ++ + g_mutex_lock (player->priv->yes_or_no); + player->priv->thread = g_thread_create (get_cd_tracks, player, FALSE, NULL); + g_mutex_unlock (player->priv->yes_or_no); +diff --git a/src/metadata.c b/src/metadata.c +index d5289e7..47d0f5d 100644 +--- src/metadata.c ++++ src/metadata.c +@@ -22,124 +22,163 @@ + + #include <config.h> + #include <stdio.h> +-#include <musicbrainz/queries.h> +-#include <musicbrainz/mb_c.h> ++#include <string.h> ++#include <musicbrainz3/mb_c.h> + #include "glib-utils.h" + #include "metadata.h" + #include "album-info.h" + + +-static AlbumInfo* +-get_album_info (musicbrainz_t mb, +- int n_album) ++static TrackInfo * ++get_track_info (MbTrack mb_track, ++ int n_track) ++{ ++ TrackInfo *track; ++ char data[1024]; ++ char data2[1024]; ++ MbArtist mb_artist; ++ ++ track = track_info_new (n_track, 0, 0); ++ ++ mb_track_get_title (mb_track, data, 1024); ++ track_info_set_title (track, data); ++ ++ debug (DEBUG_INFO, "==> [MB] TRACK %d: %s\n", n_track, data); ++ ++ mb_artist = mb_track_get_artist (mb_track); ++ if (mb_artist != NULL) { ++ mb_artist_get_unique_name (mb_artist, data, 1024); ++ mb_artist_get_id (mb_artist, data2, 1024); ++ track_info_set_artist (track, data, data2); ++ } ++ ++ return track; ++} ++ ++ ++static AlbumInfo * ++get_album_info (MbRelease release) + { + AlbumInfo *album; + char data[1024]; +- int n_track, n_tracks; +- GList *tracks = NULL; +- +- /*mb_Select (mb, MBS_Rewind);*/ +- if (! mb_Select1 (mb, MBS_SelectAlbum, n_album)) +- return NULL; ++ int i; ++ MbArtist artist; ++ char data2[1024]; ++ GList *tracks = NULL; ++ int n_tracks; + + album = album_info_new (); +- +- if (mb_GetResultData (mb, MBE_AlbumGetAlbumId, data, sizeof (data))) { +- char data2[1024]; +- mb_GetIDFromURL (mb, data, data2, sizeof (data2)); +- debug (DEBUG_INFO, "==> [MB] ALBUM_ID: %s (%s)\n", data, data2); +- album_info_set_id (album, data2); +- } +- else +- return album; +- +- if (mb_GetResultData (mb, MBE_AlbumGetAlbumName, data, sizeof (data))) { +- album_info_set_title (album, data); +- debug (DEBUG_INFO, "==> [MB] ALBUM NAME: %s\n", data); +- } +- +- if (mb_GetResultData (mb, MBE_AlbumGetAmazonAsin, data, sizeof (data))) { +- album_info_set_asin (album, data); +- debug (DEBUG_INFO, "==> [MB] ASIN: %s\n", data); +- } +- +- if (mb_GetResultInt (mb, MBE_AlbumGetNumReleaseDates) >= 1) { +- int y = 0, m = 0, d = 0; +- +- mb_Select1 (mb, MBS_SelectReleaseDate, 1); +- +- mb_GetResultData (mb, MBE_ReleaseGetDate, data, sizeof (data)); ++ ++ mb_release_get_id (release, data, 1024); ++ debug (DEBUG_INFO, "==> [MB] ALBUM_ID: %s\n", data); ++ album_info_set_id (album, strrchr (data, '/') + 1); ++ ++ mb_release_get_title (release, data, 1024); ++ debug (DEBUG_INFO, "==> [MB] ALBUM NAME: %s\n", data); ++ album_info_set_title (album, data); ++ ++ mb_release_get_asin (release, data, 1024); ++ debug (DEBUG_INFO, "==> [MB] ASIN: %s\n", data); ++ album_info_set_asin (album, data); ++ ++ for (i = 0; i < mb_release_get_num_release_events (release); i++) { ++ MbReleaseEvent event; ++ int y = 0, m = 0, d = 0; ++ ++ event = mb_release_get_release_event (release, i); ++ mb_release_event_get_date (event, data, 1024); + debug (DEBUG_INFO, "==> [MB] RELEASE DATE: %s\n", data); + if (sscanf (data, "%d-%d-%d", &y, &m, &d) > 0) { + GDate *date; +- ++ + date = g_date_new_dmy ((d > 0) ? d : 1, (m > 0) ? m : 1, (y > 0) ? y : 1); + album_info_set_release_date (album, date); + g_date_free (date); + } +- +- mb_GetResultData (mb, MBE_ReleaseGetCountry, data, sizeof (data)); +- debug (DEBUG_INFO, "==> [MB] RELEASE COUNTRY: %s\n", data); +- +- mb_Select (mb, MBS_Back); +- } +- +- if (mb_GetResultData (mb, MBE_AlbumGetAlbumArtistName, data, sizeof (data))) { +- char data2[1024], data3[1024]; +- +- mb_GetResultData (mb, MBE_AlbumGetArtistId, data2, sizeof (data2)); +- mb_GetIDFromURL (mb, data2, data3, sizeof (data3)); +- +- debug (DEBUG_INFO, "==> [MB] ARTIST_ID: %s (%s)\n", data2, data3); +- +- album_info_set_artist (album, data, data3); + } +- ++ ++ artist = mb_release_get_artist (release); ++ mb_artist_get_unique_name (artist, data, 1024); ++ mb_artist_get_id (artist, data2, 1024); ++ album_info_set_artist (album, data, data2); ++ + tracks = NULL; +- n_tracks = mb_GetResultInt (mb, MBE_AlbumGetNumTracks); ++ n_tracks = mb_release_get_num_tracks (release); + debug (DEBUG_INFO, "==> [MB] N TRACKS: %d\n", n_tracks); +- for (n_track = 1; n_track <= n_tracks; n_track++) { ++ for (i = 0; i < n_tracks; i++) { ++ MbTrack mb_track; + TrackInfo *track; +- +- track = track_info_new (n_track - 1, 0, 0); ++ ++ mb_track = mb_release_get_track (release, i); ++ track = get_track_info (mb_track, i); ++ if (album->artist == NULL) ++ album_info_set_artist (album, track->artist, KEEP_PREVIOUS_VALUE); + tracks = g_list_prepend (tracks, track); +- +- if (mb_GetResultData1 (mb, MBE_AlbumGetTrackName, data, sizeof (data), n_track)) +- track_info_set_title (track, data); +- +- debug (DEBUG_INFO, "==> [MB] TRACK %d: %s\n", n_track, data); +- +- if (mb_GetResultData1 (mb, MBE_AlbumGetArtistName, data, sizeof (data), n_track)) { +- char data2[1024], data3[1024]; +- +- mb_GetResultData1 (mb, MBE_AlbumGetArtistId, data2, sizeof (data2), n_track); +- mb_GetIDFromURL (mb, data2, data3, sizeof (data3)); +- track_info_set_artist (track, data, data3); +- +- if (album->artist == NULL) +- album_info_set_artist (album, data, KEEP_PREVIOUS_VALUE); +- } + } +- mb_Select (mb, MBS_Back); +- ++ + tracks = g_list_reverse (tracks); + album_info_set_tracks (album, tracks); +- ++ + return album; + } + + +-GList* +-get_album_list (musicbrainz_t mb) ++GList * ++get_album_list (MbResultList list) + { + GList *albums = NULL; +- int n_albums, i; +- +- n_albums = mb_GetResultInt (mb, MBE_GetNumAlbums); ++ int n_albums; ++ int i; ++ ++ n_albums = mb_result_list_get_size (list); + g_print ("[MB] Num Albums: %d\n", n_albums); +- +- for (i = 1; i <= n_albums; i++) +- albums = g_list_prepend (albums, get_album_info (mb, i)); +- ++ ++ for (i = 0; i < n_albums; i++) { ++ MbRelease release; ++ ++ release = mb_result_list_get_release (list, i); ++ albums = g_list_prepend (albums, get_album_info (release)); ++ } ++ + return g_list_reverse (albums); + } ++ ++ ++void ++get_track_info_for_album_list (GList *albums) ++{ ++ GList *scan; ++ ++ for (scan = albums; scan; scan = scan->next) { ++ AlbumInfo *album = scan->data; ++ MbTrackFilter filter; ++ GList *tracks; ++ MbQuery query; ++ MbResultList list; ++ int i; ++ ++ filter = mb_track_filter_new (); ++ mb_track_filter_release_id (filter, album->id); ++ query = mb_query_new (NULL, NULL); ++ list = mb_query_get_tracks (query, filter); ++ ++ tracks = NULL; ++ for (i = 0; i < mb_result_list_get_size (list); i++) { ++ MbTrack mb_track; ++ TrackInfo *track; ++ ++ mb_track = mb_result_list_get_track (list, i); ++ track = get_track_info (mb_track, i); ++ if ((album->artist == NULL) && (track->artist != NULL)) ++ album_info_set_artist (album, track->artist, KEEP_PREVIOUS_VALUE); ++ tracks = g_list_prepend (tracks, track); ++ } ++ ++ tracks = g_list_reverse (tracks); ++ album_info_set_tracks (album, tracks); ++ ++ mb_result_list_free (list); ++ mb_query_free (query); ++ mb_track_filter_free (filter); ++ } ++} +diff --git a/src/metadata.h b/src/metadata.h +index 725de33..45526aa 100644 +--- src/metadata.h ++++ src/metadata.h +@@ -24,8 +24,9 @@ + #define METADATA_H + + #include <glib.h> +-#include <musicbrainz/mb_c.h> ++#include <musicbrainz3/mb_c.h> + +-GList* get_album_list (musicbrainz_t mb); ++GList * get_album_list (MbResultList list); ++void get_track_info_for_album_list (GList *albums); + + #endif /* METADATA_H */ diff --git a/audio/goobox/files/patch-port_to_libnotify07 b/audio/goobox/files/patch-port_to_libnotify07 new file mode 100644 index 000000000000..0301bcd21bdd --- /dev/null +++ b/audio/goobox/files/patch-port_to_libnotify07 @@ -0,0 +1,26 @@ +diff --git a/src/main.c b/src/main.c +index 9c982d7..4286740 100644 +--- src/main.c ++++ src/main.c +@@ -37,6 +37,9 @@ + + #ifdef ENABLE_NOTIFICATION + #include <libnotify/notify.h> ++#ifndef NOTIFY_CHECK_VERSION ++#define NOTIFY_CHECK_VERSION(x,y,z) 0 ++#endif + static NotifyNotification *notification = NULL; + #endif /* ENABLE_NOTIFICATION */ + +@@ -591,7 +594,11 @@ system_notify (GooWindow *window, + g_list_free (caps); + } + ++#if NOTIFY_CHECK_VERSION (0, 7, 0) ++ notification = notify_notification_new (title, msg, "goobox"); ++#else + notification = notify_notification_new_with_status_icon (title, msg, "goobox", status_icon); ++#endif + notify_notification_set_urgency (notification, NOTIFY_URGENCY_LOW); + + if (supports_actions) { diff --git a/audio/goobox/files/patch-src_cd-drive.c b/audio/goobox/files/patch-src_cd-drive.c deleted file mode 100644 index 44f796b1aa44..000000000000 --- a/audio/goobox/files/patch-src_cd-drive.c +++ /dev/null @@ -1,12 +0,0 @@ ---- src/cd-drive.c.orig Sun Dec 24 22:45:32 2006 -+++ src/cd-drive.c Sun Dec 24 22:45:12 2006 -@@ -82,6 +82,9 @@ struct CDDrivePriv { - char *udi; - }; - -+static int get_device_max_read_speed (char *device); -+static int get_device_max_write_speed (char *device); -+ - static CDDrive *cd_drive_new (void); - - /* Utility functions, be careful to have a match with what's use in the diff --git a/audio/goobox/files/patch-src_main.c b/audio/goobox/files/patch-src_main.c deleted file mode 100644 index aabcd8b783c5..000000000000 --- a/audio/goobox/files/patch-src_main.c +++ /dev/null @@ -1,11 +0,0 @@ ---- src/main.c.orig 2011-08-15 20:09:01.000000000 +0200 -+++ src/main.c 2011-08-15 20:09:22.000000000 +0200 -@@ -698,7 +698,7 @@ system_notify (GooWindow *window, - } - - if (notification == NULL) { -- notification = notify_notification_new (title, msg, "goobox", NULL); -+ notification = notify_notification_new (title, msg, "goobox"); - notify_notification_set_urgency (notification, NOTIFY_URGENCY_LOW); - notify_notification_add_action (notification, - GTK_STOCK_MEDIA_NEXT, diff --git a/audio/goobox/pkg-plist b/audio/goobox/pkg-plist index 6086d68a8e9f..5c44fc6ee158 100644 --- a/audio/goobox/pkg-plist +++ b/audio/goobox/pkg-plist @@ -1,18 +1,21 @@ bin/goobox -libdata/bonobo/servers/GNOME_Goobox.server -share/application-registry/goobox.applications share/applications/goobox.desktop share/gnome/help/goobox/C/goobox.xml share/gnome/help/goobox/C/legal.xml share/gnome/help/goobox/ca/goobox.xml +share/gnome/help/goobox/cs/goobox.xml +share/gnome/help/goobox/de/goobox.xml share/gnome/help/goobox/es/goobox.xml +share/gnome/help/goobox/fr/goobox.xml +share/gnome/help/goobox/oc/goobox.xml +share/gnome/help/goobox/sl/goobox.xml share/gnome/help/goobox/sv/goobox.xml -%%DATADIR%%/glade/cover_chooser.glade -%%DATADIR%%/glade/extract_dialog.glade -%%DATADIR%%/glade/format_dialog.glade -%%DATADIR%%/glade/preferences.glade -%%DATADIR%%/glade/properties.glade -%%DATADIR%%/glade/ripper_dialog.glade +%%DATADIR%%/ui/cover-chooser.ui +%%DATADIR%%/ui/extract.ui +%%DATADIR%%/ui/format-options.ui +%%DATADIR%%/ui/preferences.ui +%%DATADIR%%/ui/properties.ui +%%DATADIR%%/ui/ripper.ui share/icons/hicolor/48x48/apps/goobox.png share/locale/ar/LC_MESSAGES/goobox.mo share/locale/bg/LC_MESSAGES/goobox.mo @@ -29,6 +32,7 @@ share/locale/eu/LC_MESSAGES/goobox.mo share/locale/fi/LC_MESSAGES/goobox.mo share/locale/fr/LC_MESSAGES/goobox.mo share/locale/hu/LC_MESSAGES/goobox.mo +share/locale/id/LC_MESSAGES/goobox.mo share/locale/it/LC_MESSAGES/goobox.mo share/locale/ja/LC_MESSAGES/goobox.mo share/locale/ko/LC_MESSAGES/goobox.mo @@ -44,6 +48,7 @@ share/locale/pt/LC_MESSAGES/goobox.mo share/locale/pt_BR/LC_MESSAGES/goobox.mo share/locale/ru/LC_MESSAGES/goobox.mo share/locale/rw/LC_MESSAGES/goobox.mo +share/locale/sl/LC_MESSAGES/goobox.mo share/locale/sq/LC_MESSAGES/goobox.mo share/locale/sv/LC_MESSAGES/goobox.mo share/locale/vi/LC_MESSAGES/goobox.mo @@ -51,20 +56,32 @@ share/locale/zh_CN/LC_MESSAGES/goobox.mo share/locale/zh_TW/LC_MESSAGES/goobox.mo share/omf/goobox/goobox-C.omf share/omf/goobox/goobox-ca.omf +share/omf/goobox/goobox-cs.omf +share/omf/goobox/goobox-de.omf share/omf/goobox/goobox-es.omf +share/omf/goobox/goobox-fr.omf +share/omf/goobox/goobox-oc.omf +share/omf/goobox/goobox-sl.omf share/omf/goobox/goobox-sv.omf @dirrm share/omf/goobox -@dirrm %%DATADIR%%/glade -@dirrm %%DATADIR%% -@dirrm share/gnome/help/goobox/sv -@dirrm share/gnome/help/goobox/es -@dirrm share/gnome/help/goobox/ca -@dirrm share/gnome/help/goobox/C -@dirrm share/gnome/help/goobox @dirrmtry share/locale/rw/LC_MESSAGES @dirrmtry share/locale/rw @dirrmtry share/locale/oc/LC_MESSAGES @dirrmtry share/locale/oc @dirrmtry share/locale/dz/LC_MESSAGES @dirrmtry share/locale/dz +@dirrm %%DATADIR%%/ui +@dirrm %%DATADIR%% +@dirrm share/gnome/help/goobox/sv +@dirrm share/gnome/help/goobox/sl +@dirrm share/gnome/help/goobox/oc +@dirrm share/gnome/help/goobox/fr +@dirrm share/gnome/help/goobox/es +@dirrm share/gnome/help/goobox/de +@dirrm share/gnome/help/goobox/cs +@dirrm share/gnome/help/goobox/ca +@dirrm share/gnome/help/goobox/C +@dirrm share/gnome/help/goobox @dirrmtry share/applications +@exec %%LOCALBASE%%/bin/update-desktop-database > /dev/null || /usr/bin/true +@unexec %%LOCALBASE%%/bin/update-desktop-database > /dev/null || /usr/bin/true |