# HG changeset patch # User William Pitcock # Date 1186754267 18000 # Node ID 0ff7d08693f6c1cd8a0177e7117ca7c25dc9af21 # Parent 654aa79e43ef2cf84a930e3fdee5d267320c4ed2 wavpack: update to new tuple API, use std::string more. diff -r 654aa79e43ef -r 0ff7d08693f6 src/wavpack/libwavpack.cxx --- a/src/wavpack/libwavpack.cxx Fri Aug 10 08:42:59 2007 -0500 +++ b/src/wavpack/libwavpack.cxx Fri Aug 10 08:57:47 2007 -0500 @@ -1,3 +1,5 @@ +#include + #include #include #include @@ -8,7 +10,7 @@ #include #include #include -#include +#include #include #include } @@ -44,7 +46,7 @@ static bool killDecodeThread; static bool AudioError; static GThread *thread_handle; -static TitleInput *wv_get_song_tuple(char *); +static Tuple *wv_get_song_tuple(char *); // in ui.cpp void wv_configure(); @@ -354,34 +356,43 @@ return; } -static TitleInput * +static std::string +WavpackPluginGetQualityString(WavpackContext *ctx) +{ + int mode = WavpackGetMode(ctx); + + if (mode & MODE_LOSSLESS) + return "lossless"; + + if (mode & MODE_HYBRID) + return "lossy (hybrid)"; + + return "lossy"; +} + +static Tuple * tuple_from_WavpackContext(const char *fn, WavpackContext *ctx) { ape_tag tag; - TitleInput *ti; + Tuple *ti; int sample_rate = WavpackGetSampleRate(ctx); - ti = bmp_title_input_new(); - - ti->file_name = g_path_get_basename(fn); - ti->file_path = g_path_get_dirname(fn); - ti->file_ext = "wv"; + ti = tuple_new_from_filename(fn); load_tag(&tag, ctx); - ti->track_name = g_strdup(tag.title); - ti->performer = g_strdup(tag.artist); - ti->album_name = g_strdup(tag.album); - ti->date = g_strdup(tag.year); - ti->track_number = atoi(tag.track); - if (ti->track_number < 0) - ti->track_number = 0; - ti->year = atoi(tag.year); - if (ti->year < 0) - ti->year = 0; - ti->genre = g_strdup(tag.genre); - ti->comment = g_strdup(tag.comment); - ti->length = (int)(WavpackGetNumSamples(ctx) / sample_rate) * 1000; + tuple_associate_string(ti, "title", tag.title); + tuple_associate_string(ti, "artist", tag.artist); + tuple_associate_string(ti, "album", tag.album); + tuple_associate_string(ti, "genre", tag.genre); + tuple_associate_string(ti, "comment", tag.comment); + tuple_associate_string(ti, "date", tag.year); + tuple_associate_string(ti, "quality", WavpackPluginGetQualityString(ctx).c_str()); + tuple_associate_string(ti, "codec", tag.year); + + tuple_associate_int(ti, "track-number", atoi(tag.track)); + tuple_associate_int(ti, "year", atoi(tag.year)); + tuple_associate_int(ti, "length", (int)(WavpackGetNumSamples(ctx) / sample_rate) * 1000); return ti; } @@ -390,23 +401,23 @@ generate_title(const char *fn, WavpackContext *ctx) { static char *displaytitle = NULL; - TitleInput *ti; + Tuple *ti; ti = tuple_from_WavpackContext(fn, ctx); - displaytitle = xmms_get_titlestring(xmms_get_gentitle_format(), ti); + displaytitle = tuple_formatter_process_string(ti, cfg.gentitle_format); if (!displaytitle || *displaytitle == '\0') displaytitle = g_strdup(fn); - bmp_title_input_free(ti); + mowgli_object_unref((void *) ti); return displaytitle; } -static TitleInput * +static Tuple * wv_get_song_tuple(char *filename) { - TitleInput *ti; + Tuple *ti; WavpackDecoder d(&mod); if (!d.attach(filename)) { diff -r 654aa79e43ef -r 0ff7d08693f6 src/wavpack/ui.cxx --- a/src/wavpack/ui.cxx Fri Aug 10 08:42:59 2007 -0500 +++ b/src/wavpack/ui.cxx Fri Aug 10 08:57:47 2007 -0500 @@ -8,7 +8,6 @@ #include #include #include -#include #include #include }