xmms - Fix inline linking problems with old glib
[platform/upstream/flac.git] / src / plugin_xmms / fileinfo.c
index 3017073..e5e5fb1 100644 (file)
@@ -1,7 +1,7 @@
 /*  XMMS - Cross-platform multimedia player
  *  Copyright (C) 1998-2000  Peter Alm, Mikael Alm, Olle Hallnas, Thomas Nilsson and 4Front Technologies
  *  Copyright (C) 1999,2000  Håvard Kvålen
- *  Copyright (C) 2002  Daisuke Shimamura
+ *  Copyright (C) 2002,2003,2004,2005,2006,2007,2008,2009  Daisuke Shimamura
  *
  *  This program is free software; you can redistribute it and/or modify
  *  it under the terms of the GNU General Public License as published by
  *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  *  GNU General Public License for more details.
  *
- *  You should have received a copy of the GNU General Public License
- *  along with this program; if not, write to the Free Software
- *  Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ *  You should have received a copy of the GNU General Public License along
+ *  with this program; if not, write to the Free Software Foundation, Inc.,
+ *  with this program; if not, write to the Free Software Foundation, Inc.,
  */
+
+#include "plugin.h"
+
+#include <stdlib.h>
+#include <string.h> /* for strlen() */
 #include <sys/types.h>
 #include <sys/stat.h>
-#include <fcntl.h>
+#include <unistd.h>
 #include <stdarg.h>
-#include "FLAC/all.h"
-#include "id3_tag.h"
+#include <inttypes.h>
+#include <gtk/gtk.h>
+
+#include "FLAC/metadata.h"
+#include "charset.h"
 #include "configure.h"
+#include "plugin_common/replaygain.h"
+#include "plugin_common/tags.h"
+#include "locale_hack.h"
 
-gboolean get_file_info(char *filename, flac_file_info_struct *tmp_file_info)
-{
-       FLAC__StreamMetadata streaminfo;
+static GtkWidget *window = NULL;
+static GList *genre_list = NULL;
+static GtkWidget *filename_entry, *tag_frame;
+static GtkWidget *title_entry, *artist_entry, *album_entry, *date_entry, *tracknum_entry, *comment_entry;
+static GtkWidget *replaygain_reference, *replaygain_track_gain, *replaygain_album_gain, *replaygain_track_peak, *replaygain_album_peak;
+static GtkWidget *genre_combo;
+static GtkWidget *flac_samplerate, *flac_channels, *flac_bits_per_sample, *flac_blocksize, *flac_filesize, *flac_samples, *flac_bitrate;
 
-       if(0 == filename)
-               filename = "";
+static gchar *current_filename = NULL;
+static FLAC__StreamMetadata *tags_ = NULL;
 
-       if(!FLAC__metadata_get_streaminfo(filename, &streaminfo)) {
-               return FALSE;
-       }
+static const gchar *vorbis_genres[] =
+{
+       N_("Blues"), N_("Classic Rock"), N_("Country"), N_("Dance"),
+       N_("Disco"), N_("Funk"), N_("Grunge"), N_("Hip-Hop"),
+       N_("Jazz"), N_("Metal"), N_("New Age"), N_("Oldies"),
+       N_("Other"), N_("Pop"), N_("R&B"), N_("Rap"), N_("Reggae"),
+       N_("Rock"), N_("Techno"), N_("Industrial"), N_("Alternative"),
+       N_("Ska"), N_("Death Metal"), N_("Pranks"), N_("Soundtrack"),
+       N_("Euro-Techno"), N_("Ambient"), N_("Trip-Hop"), N_("Vocal"),
+       N_("Jazz+Funk"), N_("Fusion"), N_("Trance"), N_("Classical"),
+       N_("Instrumental"), N_("Acid"), N_("House"), N_("Game"),
+       N_("Sound Clip"), N_("Gospel"), N_("Noise"), N_("Alt"),
+       N_("Bass"), N_("Soul"), N_("Punk"), N_("Space"),
+       N_("Meditative"), N_("Instrumental Pop"),
+       N_("Instrumental Rock"), N_("Ethnic"), N_("Gothic"),
+       N_("Darkwave"), N_("Techno-Industrial"), N_("Electronic"),
+       N_("Pop-Folk"), N_("Eurodance"), N_("Dream"),
+       N_("Southern Rock"), N_("Comedy"), N_("Cult"),
+       N_("Gangsta Rap"), N_("Top 40"), N_("Christian Rap"),
+       N_("Pop/Funk"), N_("Jungle"), N_("Native American"),
+       N_("Cabaret"), N_("New Wave"), N_("Psychedelic"), N_("Rave"),
+       N_("Showtunes"), N_("Trailer"), N_("Lo-Fi"), N_("Tribal"),
+       N_("Acid Punk"), N_("Acid Jazz"), N_("Polka"), N_("Retro"),
+       N_("Musical"), N_("Rock & Roll"), N_("Hard Rock"), N_("Folk"),
+       N_("Folk/Rock"), N_("National Folk"), N_("Swing"),
+       N_("Fast-Fusion"), N_("Bebob"), N_("Latin"), N_("Revival"),
+       N_("Celtic"), N_("Bluegrass"), N_("Avantgarde"),
+       N_("Gothic Rock"), N_("Progressive Rock"),
+       N_("Psychedelic Rock"), N_("Symphonic Rock"), N_("Slow Rock"),
+       N_("Big Band"), N_("Chorus"), N_("Easy Listening"),
+       N_("Acoustic"), N_("Humour"), N_("Speech"), N_("Chanson"),
+       N_("Opera"), N_("Chamber Music"), N_("Sonata"), N_("Symphony"),
+       N_("Booty Bass"), N_("Primus"), N_("Porn Groove"),
+       N_("Satire"), N_("Slow Jam"), N_("Club"), N_("Tango"),
+       N_("Samba"), N_("Folklore"), N_("Ballad"), N_("Power Ballad"),
+       N_("Rhythmic Soul"), N_("Freestyle"), N_("Duet"),
+       N_("Punk Rock"), N_("Drum Solo"), N_("A Cappella"),
+       N_("Euro-House"), N_("Dance Hall"), N_("Goa"),
+       N_("Drum & Bass"), N_("Club-House"), N_("Hardcore"),
+       N_("Terror"), N_("Indie"), N_("BritPop"), N_("Negerpunk"),
+       N_("Polsk Punk"), N_("Beat"), N_("Christian Gangsta Rap"),
+       N_("Heavy Metal"), N_("Black Metal"), N_("Crossover"),
+       N_("Contemporary Christian"), N_("Christian Rock"),
+       N_("Merengue"), N_("Salsa"), N_("Thrash Metal"),
+       N_("Anime"), N_("JPop"), N_("Synthpop")
+};
+
+static void label_set_text(GtkWidget * label, char *str, ...)
+{
+       va_list args;
+       gchar *tempstr;
 
-        tmp_file_info->sample_rate     = streaminfo.data.stream_info.sample_rate;
-        tmp_file_info->channels                = streaminfo.data.stream_info.channels;
-        tmp_file_info->bits_per_sample = streaminfo.data.stream_info.bits_per_sample;
-        tmp_file_info->total_samples   = streaminfo.data.stream_info.total_samples;
+       va_start(args, str);
+       tempstr = g_strdup_vprintf(str, args);
+       va_end(args);
 
-       tmp_file_info->length_in_msec   = streaminfo.data.stream_info.total_samples * 10 / (streaminfo.data.stream_info.sample_rate / 100);
+       gtk_label_set_text(GTK_LABEL(label), tempstr);
+       g_free(tempstr);
+}
 
-       return TRUE;
+static void set_entry_tag(GtkEntry * entry, const char * utf8)
+{
+       if(utf8) {
+               if(flac_cfg.title.convert_char_set) {
+                       char *text = convert_from_utf8_to_user(utf8);
+                       gtk_entry_set_text(entry, text);
+                       free(text);
+               }
+               else
+                       gtk_entry_set_text(entry, utf8);
+       }
+       else
+               gtk_entry_set_text(entry, "");
 }
 
-static GtkWidget *window = NULL;
-static GtkWidget *filename_entry, *id3_frame;
-static GtkWidget *title_entry, *artist_entry, *album_entry, *year_entry, *tracknum_entry, *comment_entry;
-static GtkWidget *genre_combo;
-static GtkWidget *flac_level, *flac_bitrate, *flac_samplerate, *flac_flags;
-static GtkWidget *flac_fileinfo, *flac_genre;
+static void get_entry_tag(GtkEntry * entry, const char *name)
+{
+       gchar *text;
+       char *utf8;
 
-static gchar *current_filename = NULL;
+       text = gtk_entry_get_text(entry);
+       if (!text || strlen(text) == 0)
+               return;
+       if(flac_cfg.title.convert_char_set)
+               utf8 = convert_from_user_to_utf8(text);
+       else
+               utf8 = text;
 
-extern gchar *flac_filename;
-extern gint flac_bitrate, flac_frequency, flac_layer, flac_lsf, flac_mode;
-extern gboolean flac_stereo, flac_flac25;
+       FLAC_plugin__tags_add_tag_utf8(tags_, name, utf8, /*separator=*/0);
 
-#define MAX_STR_LEN 100
+       if(flac_cfg.title.convert_char_set)
+               free(utf8);
+}
 
-static void set_entry_tag(GtkEntry * entry, gchar * tag, gint length)
+static void show_tag(void)
 {
-       gint stripped_len;
-       gchar *text;
-
-       stripped_len = flac_strip_spaces(tag, length);
-       text = g_strdup_printf("%-*.*s", stripped_len, stripped_len, tag);
-       gtk_entry_set_text(entry, text);
-       g_free(text);
+       set_entry_tag(GTK_ENTRY(title_entry)                  , FLAC_plugin__tags_get_tag_utf8(tags_, "TITLE"));
+       set_entry_tag(GTK_ENTRY(artist_entry)                 , FLAC_plugin__tags_get_tag_utf8(tags_, "ARTIST"));
+       set_entry_tag(GTK_ENTRY(album_entry)                  , FLAC_plugin__tags_get_tag_utf8(tags_, "ALBUM"));
+       set_entry_tag(GTK_ENTRY(date_entry)                   , FLAC_plugin__tags_get_tag_utf8(tags_, "DATE"));
+       set_entry_tag(GTK_ENTRY(tracknum_entry)               , FLAC_plugin__tags_get_tag_utf8(tags_, "TRACKNUMBER"));
+       set_entry_tag(GTK_ENTRY(comment_entry)                , FLAC_plugin__tags_get_tag_utf8(tags_, "DESCRIPTION"));
+       set_entry_tag(GTK_ENTRY(GTK_COMBO(genre_combo)->entry), FLAC_plugin__tags_get_tag_utf8(tags_, "GENRE"));
 }
 
-static void get_entry_tag(GtkEntry * entry, gchar * tag, gint length)
+static void save_tag(GtkWidget * w, gpointer data)
 {
-       gchar *text;
+       (void)w;
+       (void)data;
+
+       FLAC_plugin__tags_delete_tag(tags_, "TITLE");
+       FLAC_plugin__tags_delete_tag(tags_, "ARTIST");
+       FLAC_plugin__tags_delete_tag(tags_, "ALBUM");
+       FLAC_plugin__tags_delete_tag(tags_, "DATE");
+       FLAC_plugin__tags_delete_tag(tags_, "TRACKNUMBER");
+       FLAC_plugin__tags_delete_tag(tags_, "DESCRIPTION");
+       FLAC_plugin__tags_delete_tag(tags_, "GENRE");
+
+       get_entry_tag(GTK_ENTRY(title_entry)                  , "TITLE");
+       get_entry_tag(GTK_ENTRY(artist_entry)                 , "ARTIST");
+       get_entry_tag(GTK_ENTRY(album_entry)                  , "ALBUM");
+       get_entry_tag(GTK_ENTRY(date_entry)                   , "DATE");
+       get_entry_tag(GTK_ENTRY(tracknum_entry)               , "TRACKNUMBER");
+       get_entry_tag(GTK_ENTRY(comment_entry)                , "DESCRIPTION");
+       get_entry_tag(GTK_ENTRY(GTK_COMBO(genre_combo)->entry), "GENRE");
+
+       FLAC_plugin__tags_set(current_filename, tags_);
+       gtk_widget_destroy(window);
+}
 
-       text = gtk_entry_get_text(entry);
-       memset(tag, ' ', length);
-       memcpy(tag, text, strlen(text) > length ? length : strlen(text));
+static void remove_tag(GtkWidget * w, gpointer data)
+{
+       (void)w;
+       (void)data;
+
+       FLAC_plugin__tags_delete_tag(tags_, "TITLE");
+       FLAC_plugin__tags_delete_tag(tags_, "ARTIST");
+       FLAC_plugin__tags_delete_tag(tags_, "ALBUM");
+       FLAC_plugin__tags_delete_tag(tags_, "DATE");
+       FLAC_plugin__tags_delete_tag(tags_, "TRACKNUMBER");
+       FLAC_plugin__tags_delete_tag(tags_, "DESCRIPTION");
+       FLAC_plugin__tags_delete_tag(tags_, "GENRE");
+
+       FLAC_plugin__tags_set(current_filename, tags_);
+       gtk_widget_destroy(window);
 }
 
-static gint genre_comp_func(gconstpointer a, gconstpointer b)
+static void show_file_info(void)
 {
-       return strcasecmp(a, b);
+       FLAC__StreamMetadata streaminfo;
+       struct stat _stat;
+
+       gtk_label_set_text(GTK_LABEL(flac_samplerate), "");
+       gtk_label_set_text(GTK_LABEL(flac_channels), "");
+       gtk_label_set_text(GTK_LABEL(flac_bits_per_sample), "");
+       gtk_label_set_text(GTK_LABEL(flac_blocksize), "");
+       gtk_label_set_text(GTK_LABEL(flac_filesize), "");
+       gtk_label_set_text(GTK_LABEL(flac_samples), "");
+       gtk_label_set_text(GTK_LABEL(flac_bitrate), "");
+
+       if(!FLAC__metadata_get_streaminfo(current_filename, &streaminfo)) {
+               return;
+       }
+
+       label_set_text(flac_samplerate, _("Samplerate: %d Hz"), streaminfo.data.stream_info.sample_rate);
+       label_set_text(flac_channels, _("Channels: %d"), streaminfo.data.stream_info.channels);
+       label_set_text(flac_bits_per_sample, _("Bits/Sample: %d"), streaminfo.data.stream_info.bits_per_sample);
+       if(streaminfo.data.stream_info.min_blocksize == streaminfo.data.stream_info.max_blocksize)
+               label_set_text(flac_blocksize, _("Blocksize: %d"), streaminfo.data.stream_info.min_blocksize);
+       else
+               label_set_text(flac_blocksize, _("Blocksize: variable\n  min/max: %d/%d"), streaminfo.data.stream_info.min_blocksize, streaminfo.data.stream_info.max_blocksize);
+
+       if (streaminfo.data.stream_info.total_samples)
+               label_set_text(flac_samples, _("Samples: %" PRIu64 "\nLength: %d:%.2d"),
+                               streaminfo.data.stream_info.total_samples,
+                               (int)(streaminfo.data.stream_info.total_samples / streaminfo.data.stream_info.sample_rate / 60),
+                               (int)(streaminfo.data.stream_info.total_samples / streaminfo.data.stream_info.sample_rate % 60));
+
+       if(!stat(current_filename, &_stat) && S_ISREG(_stat.st_mode)) {
+               label_set_text(flac_filesize, _("Filesize: %zd B"), _stat.st_size);
+               if (streaminfo.data.stream_info.total_samples)
+                       label_set_text(flac_bitrate, _("Avg. bitrate: %.1f kb/s\nCompression ratio: %.1f%%"),
+                                       8.0 * (float)(_stat.st_size) / (1000.0 * (float)streaminfo.data.stream_info.total_samples / (float)streaminfo.data.stream_info.sample_rate),
+                                       100.0 * (float)_stat.st_size / (float)(streaminfo.data.stream_info.bits_per_sample / 8 * streaminfo.data.stream_info.channels * streaminfo.data.stream_info.total_samples));
+       }
 }
 
-static gchar* channel_mode_name(int mode)
+static void show_replaygain(void)
 {
-       static const gchar *channel_mode[] =
-               {N_("Mono"), N_("Stereo")};
-       if (mode < 1 || mode > 2)
-               return "";
-       return gettext(channel_mode[mode]);
+       /* known limitation: If only one of gain and peak is set, neither will be shown. This is true for
+        * both track and album replaygain tags. Written so it will be easy to fix, with some trouble.  */
+
+       gtk_label_set_text(GTK_LABEL(replaygain_reference), "");
+       gtk_label_set_text(GTK_LABEL(replaygain_track_gain), "");
+       gtk_label_set_text(GTK_LABEL(replaygain_album_gain), "");
+       gtk_label_set_text(GTK_LABEL(replaygain_track_peak), "");
+       gtk_label_set_text(GTK_LABEL(replaygain_album_peak), "");
+
+       double reference, track_gain, track_peak, album_gain, album_peak;
+       FLAC__bool reference_set, track_gain_set, track_peak_set, album_gain_set, album_peak_set;
+
+       if(!FLAC_plugin__replaygain_get_from_file(
+               current_filename,
+               &reference, &reference_set,
+               &track_gain, &track_gain_set,
+               &album_gain, &album_gain_set,
+               &track_peak, &track_peak_set,
+               &album_peak, &album_peak_set
+       ))
+               return;
+
+       if(reference_set)
+                 label_set_text(replaygain_reference, _("ReplayGain Reference Loudness: %2.1f dB"), reference);
+       if(track_gain_set)
+                 label_set_text(replaygain_track_gain, _("ReplayGain Track Gain: %+2.2f dB"), track_gain);
+       if(album_gain_set)
+                 label_set_text(replaygain_album_gain, _("ReplayGain Album Gain: %+2.2f dB"), album_gain);
+       if(track_peak_set)
+                 label_set_text(replaygain_track_peak, _("ReplayGain Track Peak: %1.8f"), track_peak);
+       if(album_peak_set)
+                 label_set_text(replaygain_album_peak, _("ReplayGain Album Peak: %1.8f"), album_peak);
 }
 
 void FLAC_XMMS__file_info_box(char *filename)
 {
-       gint i;
-       FILE *fh;
-       gchar *tmp, *title;
-
-       gboolean rc;
-
-#ifdef FLAC__HAS_ID3LIB
-       File_Tag tag;
-       Initialize_File_Tag_Item (&tag);
-       rc = Id3tag_Read_File_Tag (filename, &tag);
-#else
-       id3v2_struct tag;
-       memset(&tag, 0, sizeof(tag));
-       rc = get_id3v1_tag_as_v2_(filename, &tag);
-#endif
+       unsigned i;
+       gchar *title;
 
        if (!window)
        {
                GtkWidget *vbox, *hbox, *left_vbox, *table;
                GtkWidget *flac_frame, *flac_box;
                GtkWidget *label, *filename_hbox;
-               GtkWidget *bbox, *save, *remove_id3, *cancel;
-               
+               GtkWidget *bbox, *save, *remove, *cancel;
+
                window = gtk_window_new(GTK_WINDOW_DIALOG);
                gtk_window_set_policy(GTK_WINDOW(window), FALSE, FALSE, FALSE);
                gtk_signal_connect(GTK_OBJECT(window), "destroy", GTK_SIGNAL_FUNC(gtk_widget_destroyed), &window);
@@ -136,61 +298,61 @@ void FLAC_XMMS__file_info_box(char *filename)
                filename_entry = gtk_entry_new();
                gtk_editable_set_editable(GTK_EDITABLE(filename_entry), FALSE);
                gtk_box_pack_start(GTK_BOX(filename_hbox), filename_entry, TRUE, TRUE, 0);
-               
+
                hbox = gtk_hbox_new(FALSE, 10);
                gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, TRUE, 0);
-               
+
                left_vbox = gtk_vbox_new(FALSE, 10);
                gtk_box_pack_start(GTK_BOX(hbox), left_vbox, FALSE, FALSE, 0);
 
-               id3_frame = gtk_frame_new(_("ID3 Tag:"));
-               gtk_box_pack_start(GTK_BOX(left_vbox), id3_frame, FALSE, FALSE, 0);
+               tag_frame = gtk_frame_new(_("Tag:"));
+               gtk_box_pack_start(GTK_BOX(left_vbox), tag_frame, FALSE, FALSE, 0);
 
                table = gtk_table_new(5, 5, FALSE);
                gtk_container_set_border_width(GTK_CONTAINER(table), 5);
-               gtk_container_add(GTK_CONTAINER(id3_frame), table);
+               gtk_container_add(GTK_CONTAINER(tag_frame), table);
 
                label = gtk_label_new(_("Title:"));
                gtk_misc_set_alignment(GTK_MISC(label), 1, 0.5);
                gtk_table_attach(GTK_TABLE(table), label, 0, 1, 0, 1, GTK_FILL, GTK_FILL, 5, 5);
 
-               title_entry = gtk_entry_new_with_max_length(30);
+               title_entry = gtk_entry_new();
                gtk_table_attach(GTK_TABLE(table), title_entry, 1, 4, 0, 1, GTK_FILL | GTK_EXPAND | GTK_SHRINK, GTK_FILL | GTK_EXPAND | GTK_SHRINK, 0, 5);
 
                label = gtk_label_new(_("Artist:"));
                gtk_misc_set_alignment(GTK_MISC(label), 1, 0.5);
                gtk_table_attach(GTK_TABLE(table), label, 0, 1, 1, 2, GTK_FILL, GTK_FILL, 5, 5);
 
-               artist_entry = gtk_entry_new_with_max_length(30);
+               artist_entry = gtk_entry_new();
                gtk_table_attach(GTK_TABLE(table), artist_entry, 1, 4, 1, 2, GTK_FILL | GTK_EXPAND | GTK_SHRINK, GTK_FILL | GTK_EXPAND | GTK_SHRINK, 0, 5);
 
                label = gtk_label_new(_("Album:"));
                gtk_misc_set_alignment(GTK_MISC(label), 1, 0.5);
                gtk_table_attach(GTK_TABLE(table), label, 0, 1, 2, 3, GTK_FILL, GTK_FILL, 5, 5);
 
-               album_entry = gtk_entry_new_with_max_length(30);
+               album_entry = gtk_entry_new();
                gtk_table_attach(GTK_TABLE(table), album_entry, 1, 4, 2, 3, GTK_FILL | GTK_EXPAND | GTK_SHRINK, GTK_FILL | GTK_EXPAND | GTK_SHRINK, 0, 5);
 
                label = gtk_label_new(_("Comment:"));
                gtk_misc_set_alignment(GTK_MISC(label), 1, 0.5);
                gtk_table_attach(GTK_TABLE(table), label, 0, 1, 3, 4, GTK_FILL, GTK_FILL, 5, 5);
 
-               comment_entry = gtk_entry_new_with_max_length(30);
+               comment_entry = gtk_entry_new();
                gtk_table_attach(GTK_TABLE(table), comment_entry, 1, 4, 3, 4, GTK_FILL | GTK_EXPAND | GTK_SHRINK, GTK_FILL | GTK_EXPAND | GTK_SHRINK, 0, 5);
 
-               label = gtk_label_new(_("Year:"));
+               label = gtk_label_new(_("Date:"));
                gtk_misc_set_alignment(GTK_MISC(label), 1, 0.5);
                gtk_table_attach(GTK_TABLE(table), label, 0, 1, 4, 5, GTK_FILL, GTK_FILL, 5, 5);
 
-               year_entry = gtk_entry_new_with_max_length(4);
-               gtk_widget_set_usize(year_entry, 40, -1);
-               gtk_table_attach(GTK_TABLE(table), year_entry, 1, 2, 4, 5, GTK_FILL | GTK_EXPAND | GTK_SHRINK, GTK_FILL | GTK_EXPAND | GTK_SHRINK, 0, 5);
+               date_entry = gtk_entry_new();
+               gtk_widget_set_usize(date_entry, 40, -1);
+               gtk_table_attach(GTK_TABLE(table), date_entry, 1, 2, 4, 5, GTK_FILL | GTK_EXPAND | GTK_SHRINK, GTK_FILL | GTK_EXPAND | GTK_SHRINK, 0, 5);
 
                label = gtk_label_new(_("Track number:"));
                gtk_misc_set_alignment(GTK_MISC(label), 1, 0.5);
                gtk_table_attach(GTK_TABLE(table), label, 2, 3, 4, 5, GTK_FILL, GTK_FILL, 5, 5);
 
-               tracknum_entry = gtk_entry_new_with_max_length(3);
+               tracknum_entry = gtk_entry_new();
                gtk_widget_set_usize(tracknum_entry, 40, -1);
                gtk_table_attach(GTK_TABLE(table), tracknum_entry, 3, 4, 4, 5, GTK_FILL | GTK_EXPAND | GTK_SHRINK, GTK_FILL | GTK_EXPAND | GTK_SHRINK, 0, 5);
 
@@ -199,13 +361,14 @@ void FLAC_XMMS__file_info_box(char *filename)
                gtk_table_attach(GTK_TABLE(table), label, 0, 1, 5, 6, GTK_FILL, GTK_FILL, 5, 5);
 
                genre_combo = gtk_combo_new();
-               gtk_entry_set_editable(GTK_ENTRY(GTK_COMBO(genre_combo)->entry), FALSE);
+               gtk_entry_set_editable(GTK_ENTRY(GTK_COMBO(genre_combo)->entry), TRUE);
+
                if (!genre_list)
                {
-                       for (i = 0; i < GENRE_MAX; i++)
-                               genre_list = g_list_prepend(genre_list, (char *) flac_id3_genres[i]);
+                       for (i = 0; i < sizeof(vorbis_genres) / sizeof(*vorbis_genres) ; i++)
+                               genre_list = g_list_prepend(genre_list, (char *)vorbis_genres[i]);
                        genre_list = g_list_prepend(genre_list, "");
-                       genre_list = g_list_sort(genre_list, genre_comp_func);
+                       genre_list = g_list_sort(genre_list, (GCompareFunc)g_strcasecmp);
                }
                gtk_combo_set_popdown_strings(GTK_COMBO(genre_combo), genre_list);
 
@@ -217,15 +380,15 @@ void FLAC_XMMS__file_info_box(char *filename)
                gtk_box_pack_start(GTK_BOX(left_vbox), bbox, FALSE, FALSE, 0);
 
                save = gtk_button_new_with_label(_("Save"));
-               gtk_signal_connect(GTK_OBJECT(save), "clicked", GTK_SIGNAL_FUNC(save_cb), NULL);
+               gtk_signal_connect(GTK_OBJECT(save), "clicked", GTK_SIGNAL_FUNC(save_tag), NULL);
                GTK_WIDGET_SET_FLAGS(save, GTK_CAN_DEFAULT);
                gtk_box_pack_start(GTK_BOX(bbox), save, TRUE, TRUE, 0);
                gtk_widget_grab_default(save);
 
-               remove_id3 = gtk_button_new_with_label(_("Remove ID3"));
-               gtk_signal_connect(GTK_OBJECT(remove_id3), "clicked", GTK_SIGNAL_FUNC(remove_id3_cb), NULL);
-               GTK_WIDGET_SET_FLAGS(remove_id3, GTK_CAN_DEFAULT);
-               gtk_box_pack_start(GTK_BOX(bbox), remove_id3, TRUE, TRUE, 0);
+               remove= gtk_button_new_with_label(_("Remove Tag"));
+               gtk_signal_connect(GTK_OBJECT(remove), "clicked", GTK_SIGNAL_FUNC(remove_tag), NULL);
+               GTK_WIDGET_SET_FLAGS(remove, GTK_CAN_DEFAULT);
+               gtk_box_pack_start(GTK_BOX(bbox), remove, TRUE, TRUE, 0);
 
                cancel = gtk_button_new_with_label(_("Cancel"));
                gtk_signal_connect_object(GTK_OBJECT(cancel), "clicked", GTK_SIGNAL_FUNC(gtk_widget_destroy), GTK_OBJECT(window));
@@ -240,36 +403,73 @@ void FLAC_XMMS__file_info_box(char *filename)
                gtk_container_set_border_width(GTK_CONTAINER(flac_box), 10);
                gtk_box_set_spacing(GTK_BOX(flac_box), 0);
 
-               flac_level = gtk_label_new("");
-               gtk_widget_set_usize(flac_level, 120, -2);
-               gtk_misc_set_alignment(GTK_MISC(flac_level), 0, 0);
-               gtk_box_pack_start(GTK_BOX(flac_box), flac_level, FALSE, FALSE, 0);
+               flac_samplerate = gtk_label_new("");
+               gtk_misc_set_alignment(GTK_MISC(flac_samplerate), 0, 0);
+               gtk_label_set_justify(GTK_LABEL(flac_samplerate), GTK_JUSTIFY_LEFT);
+               gtk_box_pack_start(GTK_BOX(flac_box), flac_samplerate, FALSE, FALSE, 0);
+
+               flac_channels = gtk_label_new("");
+               gtk_misc_set_alignment(GTK_MISC(flac_channels), 0, 0);
+               gtk_label_set_justify(GTK_LABEL(flac_channels), GTK_JUSTIFY_LEFT);
+               gtk_box_pack_start(GTK_BOX(flac_box), flac_channels, FALSE, FALSE, 0);
+
+               flac_bits_per_sample = gtk_label_new("");
+               gtk_misc_set_alignment(GTK_MISC(flac_bits_per_sample), 0, 0);
+               gtk_label_set_justify(GTK_LABEL(flac_bits_per_sample), GTK_JUSTIFY_LEFT);
+               gtk_box_pack_start(GTK_BOX(flac_box), flac_bits_per_sample, FALSE, FALSE, 0);
+
+               flac_blocksize = gtk_label_new("");
+               gtk_misc_set_alignment(GTK_MISC(flac_blocksize), 0, 0);
+               gtk_label_set_justify(GTK_LABEL(flac_blocksize), GTK_JUSTIFY_LEFT);
+               gtk_box_pack_start(GTK_BOX(flac_box), flac_blocksize, FALSE, FALSE, 0);
+
+               flac_filesize = gtk_label_new("");
+               gtk_misc_set_alignment(GTK_MISC(flac_filesize), 0, 0);
+               gtk_label_set_justify(GTK_LABEL(flac_filesize), GTK_JUSTIFY_LEFT);
+               gtk_box_pack_start(GTK_BOX(flac_box), flac_filesize, FALSE, FALSE, 0);
+
+               flac_samples = gtk_label_new("");
+               gtk_misc_set_alignment(GTK_MISC(flac_samples), 0, 0);
+               gtk_label_set_justify(GTK_LABEL(flac_samples), GTK_JUSTIFY_LEFT);
+               gtk_box_pack_start(GTK_BOX(flac_box), flac_samples, FALSE, FALSE, 0);
 
                flac_bitrate = gtk_label_new("");
                gtk_misc_set_alignment(GTK_MISC(flac_bitrate), 0, 0);
                gtk_label_set_justify(GTK_LABEL(flac_bitrate), GTK_JUSTIFY_LEFT);
                gtk_box_pack_start(GTK_BOX(flac_box), flac_bitrate, FALSE, FALSE, 0);
 
-               flac_samplerate = gtk_label_new("");
-               gtk_misc_set_alignment(GTK_MISC(flac_samplerate), 0, 0);
-               gtk_box_pack_start(GTK_BOX(flac_box), flac_samplerate, FALSE, FALSE, 0);
+               replaygain_reference = gtk_label_new("");
+               gtk_misc_set_alignment(GTK_MISC(replaygain_reference), 0, 0);
+               gtk_label_set_justify(GTK_LABEL(replaygain_reference), GTK_JUSTIFY_LEFT);
+               gtk_box_pack_start(GTK_BOX(flac_box), replaygain_reference, FALSE, FALSE, 0);
+
+               replaygain_track_gain = gtk_label_new("");
+               gtk_misc_set_alignment(GTK_MISC(replaygain_track_gain), 0, 0);
+               gtk_label_set_justify(GTK_LABEL(replaygain_track_gain), GTK_JUSTIFY_LEFT);
+               gtk_box_pack_start(GTK_BOX(flac_box), replaygain_track_gain, FALSE, FALSE, 0);
+
+               replaygain_album_gain = gtk_label_new("");
+               gtk_misc_set_alignment(GTK_MISC(replaygain_album_gain), 0, 0);
+               gtk_label_set_justify(GTK_LABEL(replaygain_album_gain), GTK_JUSTIFY_LEFT);
+               gtk_box_pack_start(GTK_BOX(flac_box), replaygain_album_gain, FALSE, FALSE, 0);
 
-               flac_flags = gtk_label_new("");
-               gtk_misc_set_alignment(GTK_MISC(flac_flags), 0, 0);
-               gtk_label_set_justify(GTK_LABEL(flac_flags), GTK_JUSTIFY_LEFT);
-               gtk_box_pack_start(GTK_BOX(flac_box), flac_flags, FALSE, FALSE, 0);
+               replaygain_track_peak = gtk_label_new("");
+               gtk_misc_set_alignment(GTK_MISC(replaygain_track_peak), 0, 0);
+               gtk_label_set_justify(GTK_LABEL(replaygain_track_peak), GTK_JUSTIFY_LEFT);
+               gtk_box_pack_start(GTK_BOX(flac_box), replaygain_track_peak, FALSE, FALSE, 0);
 
-               flac_fileinfo = gtk_label_new("");
-               gtk_misc_set_alignment(GTK_MISC(flac_fileinfo), 0, 0);
-               gtk_label_set_justify(GTK_LABEL(flac_fileinfo), GTK_JUSTIFY_LEFT);
-               gtk_box_pack_start(GTK_BOX(flac_box), flac_fileinfo, FALSE, FALSE, 0);
+               replaygain_album_peak = gtk_label_new("");
+               gtk_misc_set_alignment(GTK_MISC(replaygain_album_peak), 0, 0);
+               gtk_label_set_justify(GTK_LABEL(replaygain_album_peak), GTK_JUSTIFY_LEFT);
+               gtk_box_pack_start(GTK_BOX(flac_box), replaygain_album_peak, FALSE, FALSE, 0);
 
                gtk_widget_show_all(window);
        }
 
-       if (current_filename)
+       if(current_filename)
                g_free(current_filename);
-       current_filename = g_strdup(filename);
+       if(!(current_filename = g_strdup(filename)))
+               return;
 
        title = g_strdup_printf(_("File Info - %s"), g_basename(filename));
        gtk_window_set_title(GTK_WINDOW(window), title);
@@ -278,48 +478,14 @@ void FLAC_XMMS__file_info_box(char *filename)
        gtk_entry_set_text(GTK_ENTRY(filename_entry), filename);
        gtk_editable_set_position(GTK_EDITABLE(filename_entry), -1);
 
-       if (tag.title != NULL && strlen(tag.title) > 0)
-       {
-               gtk_entry_set_text(GTK_ENTRY(title_entry), tag.title);
-       }
-       else
-       {
-               title = g_strdup(g_basename(filename));
-               if ((tmp = strrchr(title, '.')) != NULL)
-                       *tmp = '\0';
-               gtk_entry_set_text(GTK_ENTRY(title_entry), title);
-               g_free(title);
-       }
+       if(tags_)
+               FLAC_plugin__tags_destroy(&tags_);
 
-       gtk_entry_set_text(GTK_ENTRY(artist_entry), tag.artist);
-       gtk_entry_set_text(GTK_ENTRY(album_entry), tag.album);
-       gtk_entry_set_text(GTK_ENTRY(year_entry), tag.year);
-       gtk_entry_set_text(GTK_ENTRY(tracknum_entry), tag.track);
-       gtk_entry_set_text(GTK_ENTRY(comment_entry), tag.comment);
-       gtk_entry_set_text(GTK_ENTRY(genre_entry), tag.genre);
+       FLAC_plugin__tags_get(current_filename, &tags_);
 
-       gtk_label_set_text(GTK_LABEL(flac_level), "");
-       gtk_label_set_text(GTK_LABEL(flac_bitrate), "");
-       gtk_label_set_text(GTK_LABEL(flac_samplerate), "");
-       gtk_label_set_text(GTK_LABEL(flac_flags), "");
-       gtk_label_set_text(GTK_LABEL(flac_fileinfo), "");
-
-       if (!strncasecmp(filename, "http://", 7))
-       {
-               file_info_http(filename);
-               return;
-       }
+       show_tag();
+       show_file_info();
+       show_replaygain();
 
-       gtk_widget_set_sensitive(id3_frame, TRUE);
-
-       label_set_text(flac_bitrate, _("Bits/Samples: %d"), tmp_file_info->bits_per_sample);
-       /* tmp_file_info->length_in_msec */
-
-       label_set_text(flac_samplerate, _("Samplerate: %ld Hz"),         tmp_file_info->sample_rate);
-       label_set_text(flac_channel, _("Channel: %s"), channel_mode_name(tmp_file_info->channel);
-#if 0
-       label_set_text(flac_fileinfo, _("%d frames\nFilesize: %lu B"), num_frames, ftell(fh));
-#endif
+       gtk_widget_set_sensitive(tag_frame, TRUE);
 }
-
-