summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGravatar waker <wakeroid@gmail.com>2011-01-22 19:30:40 +0100
committerGravatar waker <wakeroid@gmail.com>2011-01-22 19:30:40 +0100
commita07ddff5c150c5402fd9281c64ce578906f7ab6a (patch)
tree47fc67dabc03f6c45705ea3719183f55a8dded0f
parent37fac17dab627cfbca21660e3232c9295bb490dd (diff)
fixed/improved charset conversion in gme and dumb plugins
-rw-r--r--plugins/dumb/cdumb.c2
-rw-r--r--plugins/gme/cgme.c44
2 files changed, 37 insertions, 9 deletions
diff --git a/plugins/dumb/cdumb.c b/plugins/dumb/cdumb.c
index 33c54cb2..d0021403 100644
--- a/plugins/dumb/cdumb.c
+++ b/plugins/dumb/cdumb.c
@@ -711,7 +711,7 @@ static const char *convstr (const char* str, int sz) {
return out;
}
- if (deadbeef->junk_iconv (str, sz, out, sizeof (out), "utf-8", "iso8859-1") >= 0) {
+ if (deadbeef->junk_iconv (str, sz, out, sizeof (out), "iso8859-1", "utf-8") >= 0) {
return out;
}
diff --git a/plugins/gme/cgme.c b/plugins/gme/cgme.c
index e117fab8..042eb670 100644
--- a/plugins/gme/cgme.c
+++ b/plugins/gme/cgme.c
@@ -201,6 +201,34 @@ cgme_seek (DB_fileinfo_t *_info, float time) {
return 0;
}
+static void
+cgme_add_meta (DB_playItem_t *it, const char *key, const char *value) {
+ if (!value) {
+ return;
+ }
+ char len = strlen (value);
+ char out[1024];
+ // check for utf8 (hack)
+ if (deadbeef->junk_iconv (value, len, out, sizeof (out), "utf-8", "utf-8") >= 0) {
+ deadbeef->pl_add_meta (it, key, out);
+ return;
+ }
+
+ if (deadbeef->junk_iconv (value, len, out, sizeof (out), "iso8859-1", "utf-8") >= 0) {
+ deadbeef->pl_add_meta (it, key, out);
+ return;
+ }
+
+ if (deadbeef->junk_iconv (value, len, out, sizeof (out), "SHIFT-JIS", "utf-8") >= 0) {
+ deadbeef->pl_add_meta (it, key, out);
+ return;
+ }
+
+ // FIXME: try other encodings?
+
+ return;
+}
+
static DB_playItem_t *
cgme_insert (DB_playItem_t *after, const char *fname) {
Music_Emu *emu;
@@ -250,8 +278,8 @@ cgme_insert (DB_playItem_t *after, const char *fname) {
it->tracknum = i;
// add metadata
- deadbeef->pl_add_meta (it, "system", inf->system);
- deadbeef->pl_add_meta (it, "album", inf->game);
+ cgme_add_meta (it, "system", inf->system);
+ cgme_add_meta (it, "album", inf->game);
int tl = sizeof (inf->song);
int n;
for (n = 0; i < tl && inf->song[n] && inf->song[n] == ' '; n++);
@@ -259,15 +287,15 @@ cgme_insert (DB_playItem_t *after, const char *fname) {
deadbeef->pl_add_meta (it, "title", NULL);
}
else {
- deadbeef->pl_add_meta (it, "title", inf->song);
+ cgme_add_meta (it, "title", inf->song);
}
- deadbeef->pl_add_meta (it, "artist", inf->author);
- deadbeef->pl_add_meta (it, "copyright", inf->copyright);
- deadbeef->pl_add_meta (it, "comment", inf->comment);
- deadbeef->pl_add_meta (it, "dumper", inf->dumper);
+ cgme_add_meta (it, "artist", inf->author);
+ cgme_add_meta (it, "copyright", inf->copyright);
+ cgme_add_meta (it, "comment", inf->comment);
+ cgme_add_meta (it, "dumper", inf->dumper);
char trk[10];
snprintf (trk, 10, "%d", i+1);
- deadbeef->pl_add_meta (it, "track", trk);
+ cgme_add_meta (it, "track", trk);
if (inf->length == -1 || inf->length == 0) {
float songlength = deadbeef->conf_get_float ("gme.songlength", 3);
deadbeef->pl_set_item_duration (it, songlength * 60.f);