/* This file is part of Clementine. Copyright 2010, David Sansome Clementine is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. Clementine is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of 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 Clementine. If not, see . */ #include "lastfmtrackinfoprovider.h" #include "songinfoprovider.h" #include "songinfoview.h" #include "ultimatelyricsprovider.h" #include "ultimatelyricsreader.h" #include #include #include #include const char* SongInfoView::kSettingsGroup = "SongInfo"; typedef QList ProviderList; SongInfoView::SongInfoView(QWidget* parent) : SongInfoBase(parent), ultimate_reader_(new UltimateLyricsReader(this)) { // Parse the ultimate lyrics xml file in the background QFuture future = QtConcurrent::run( ultimate_reader_.get(), &UltimateLyricsReader::Parse, QString(":lyrics/ultimate_providers.xml")); QFutureWatcher* watcher = new QFutureWatcher(this); watcher->setFuture(future); connect(watcher, SIGNAL(finished()), SLOT(UltimateLyricsParsed())); fetcher_->AddProvider(new LastfmTrackInfoProvider); } SongInfoView::~SongInfoView() { } void SongInfoView::UltimateLyricsParsed() { QFutureWatcher* watcher = static_cast*>(sender()); foreach (SongInfoProvider* provider, watcher->result()) { fetcher_->AddProvider(provider); } watcher->deleteLater(); ultimate_reader_.reset(); ReloadSettings(); } bool SongInfoView::NeedsUpdate(const Song& old_metadata, const Song& new_metadata) const { if (new_metadata.title().isEmpty() || new_metadata.artist().isEmpty()) return false; return old_metadata.title() != new_metadata.title() || old_metadata.artist() != new_metadata.artist(); } void SongInfoView::ResultReady(int id, const SongInfoFetcher::Result& result) { if (id != current_request_id_) return; Clear(); foreach (const CollapsibleInfoPane::Data& data, result.info_) { AddSection(new CollapsibleInfoPane(data, this)); } CollapseSections(); } void SongInfoView::ReloadSettings() { QSettings s; s.beginGroup(kSettingsGroup); // Put the providers in the right order QList ordered_providers; QVariant saved_order = s.value("search_order"); if (saved_order.isNull()) { // Hardcoded default order ordered_providers << ProviderByName("lyrics.wikia.com") << ProviderByName("lyricstime.com") << ProviderByName("lyricsreg.com") << ProviderByName("lyricsmania.com") << ProviderByName("metrolyrics.com") << ProviderByName("azlyrics.com") << ProviderByName("songlyrics.com") << ProviderByName("elyrics.net") << ProviderByName("lyricsdownload.com") << ProviderByName("lyrics.com") << ProviderByName("lyricsbay.com") << ProviderByName("directlyrics.com") << ProviderByName("loudson.gs") << ProviderByName("teksty.org") << ProviderByName("tekstowo.pl (Polish translations)") << ProviderByName("vagalume.uol.com.br") << ProviderByName("vagalume.uol.com.br (Portuguese translations)"); } else { foreach (const QVariant& name, saved_order.toList()) { SongInfoProvider* provider = ProviderByName(name.toString()); if (provider) ordered_providers << provider; } } // Enable all the providers in the list and rank them int relevance = 100; foreach (SongInfoProvider* provider, ordered_providers) { provider->set_enabled(true); qobject_cast(provider)->set_relevance(relevance--); } // Any lyric providers we don't have in ordered_providers are considered disabled foreach (SongInfoProvider* provider, fetcher_->providers()) { if (qobject_cast(provider) && !ordered_providers.contains(provider)) { provider->set_enabled(false); } } SongInfoBase::ReloadSettings(); } SongInfoProvider* SongInfoView::ProviderByName(const QString& name) const { foreach (SongInfoProvider* provider, fetcher_->providers()) { if (UltimateLyricsProvider* lyrics = qobject_cast(provider)) { if (lyrics->name() == name) return provider; } } return NULL; } namespace { bool CompareLyricProviders(const UltimateLyricsProvider* a, const UltimateLyricsProvider* b) { if (a->is_enabled() && !b->is_enabled()) return true; if (!a->is_enabled() && b->is_enabled()) return false; return a->relevance() > b->relevance(); } } QList SongInfoView::lyric_providers() const { QList ret; foreach (SongInfoProvider* provider, fetcher_->providers()) { if (UltimateLyricsProvider* lyrics = qobject_cast(provider)) { ret << lyrics; } } qSort(ret.begin(), ret.end(), CompareLyricProviders); return ret; }