1
0
mirror of https://github.com/clementine-player/Clementine synced 2024-12-16 19:31:02 +01:00

Untested attempt to read album artist tags from ogg/flac/mp4 properly.

Fixes issue #1624
This commit is contained in:
John Maguire 2011-05-26 15:30:42 +00:00
parent e8e882b33c
commit 799279afcd

View File

@ -32,6 +32,7 @@
#include <id3v1genres.h> #include <id3v1genres.h>
#include <id3v2tag.h> #include <id3v2tag.h>
#include <mp4file.h> #include <mp4file.h>
#include <mp4tag.h>
#include <mpcfile.h> #include <mpcfile.h>
#include <mpegfile.h> #include <mpegfile.h>
#include <oggfile.h> #include <oggfile.h>
@ -368,6 +369,18 @@ void Song::InitFromFile(const QString& filename, int directory_id) {
ParseOggTag(file->xiphComment()->fieldListMap(), NULL, &disc, &compilation); ParseOggTag(file->xiphComment()->fieldListMap(), NULL, &disc, &compilation);
} }
d->comment_ = Decode(tag->comment()); d->comment_ = Decode(tag->comment());
} else if (TagLib::MP4::File* file = dynamic_cast<TagLib::MP4::File*>(fileref->file())) {
if (file->tag()) {
TagLib::MP4::Tag* mp4_tag = file->tag();
const TagLib::MP4::ItemListMap& items = mp4_tag->itemListMap();
TagLib::MP4::ItemListMap::ConstIterator it = items.find("aART");
if (it != items.end()) {
TagLib::StringList album_artists = it->second.toStringList();
if (!album_artists.isEmpty()) {
d->albumartist_ = Decode(album_artists.front());
}
}
}
} else if (tag) { } else if (tag) {
d->comment_ = Decode(tag->comment()); d->comment_ = Decode(tag->comment());
} }
@ -452,8 +465,11 @@ void Song::ParseOggTag(const TagLib::Ogg::FieldListMap& map, const QTextCodec* c
if (!map["COMPOSER"].isEmpty()) if (!map["COMPOSER"].isEmpty())
d->composer_ = Decode(map["COMPOSER"].front(), codec); d->composer_ = Decode(map["COMPOSER"].front(), codec);
if (!map["ALBUMARTIST"].isEmpty()) if (!map["ALBUMARTIST"].isEmpty()) {
d->albumartist_ = Decode(map["ALBUMARTIST"].front(), codec); d->albumartist_ = Decode(map["ALBUMARTIST"].front(), codec);
} else if (!map["ALBUM ARTIST"].isEmpty()) {
d->albumartist_ = Decode(map["ALBUM ARTIST"].front(), codec);
}
if (!map["BPM"].isEmpty() ) if (!map["BPM"].isEmpty() )
d->bpm_ = TStringToQString( map["BPM"].front() ).trimmed().toFloat(); d->bpm_ = TStringToQString( map["BPM"].front() ).trimmed().toFloat();