Clementine-audio-player-Mac.../src/songinfo/songinfoview.cpp

163 lines
5.2 KiB
C++

/* This file is part of Clementine.
Copyright 2010, David Sansome <me@davidsansome.com>
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 <http://www.gnu.org/licenses/>.
*/
#include "songinfo/songinfoview.h"
#include <QFuture>
#include <QSettings>
#include <QtConcurrentRun>
#include <algorithm>
#include "config.h"
#include "core/closure.h"
#include "songinfo/songinfoprovider.h"
#include "songinfo/taglyricsinfoprovider.h"
#include "songinfo/ultimatelyricsprovider.h"
#include "songinfo/ultimatelyricsreader.h"
#ifdef HAVE_LIBLASTFM
#include "songinfo/lastfmtrackinfoprovider.h"
#endif
const char* SongInfoView::kSettingsGroup = "SongInfo";
SongInfoView::SongInfoView(QWidget* parent)
: SongInfoBase(parent), ultimate_reader_(new UltimateLyricsReader(this)) {
// Parse the ultimate lyrics xml file in the background
QFuture<ProviderList> future =
QtConcurrent::run(ultimate_reader_.get(), &UltimateLyricsReader::Parse,
QString(":lyrics/ultimate_providers.xml"));
NewClosure(future, this, SLOT(UltimateLyricsParsed(QFuture<ProviderList>)),
future);
#ifdef HAVE_LIBLASTFM
fetcher_->AddProvider(new LastfmTrackInfoProvider);
#endif
fetcher_->AddProvider(new TagLyricsInfoProvider);
}
SongInfoView::~SongInfoView() {}
void SongInfoView::UltimateLyricsParsed(QFuture<ProviderList> future) {
for (SongInfoProvider* provider : future.result()) {
fetcher_->AddProvider(provider);
}
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::InfoResultReady(int id,
const CollapsibleInfoPane::Data& data) {
if (id != current_request_id_) return;
AddSection(new CollapsibleInfoPane(data, this));
CollapseSections();
}
void SongInfoView::ResultReady(int id, const SongInfoFetcher::Result& result) {}
void SongInfoView::ReloadSettings() {
QSettings s;
s.beginGroup(kSettingsGroup);
// Put the providers in the right order
QList<SongInfoProvider*> ordered_providers;
QVariantList default_order;
default_order << "lyrics.wikia.com"
<< "lyricsreg.com"
<< "lyricsmania.com"
<< "azlyrics.com"
<< "songlyrics.com"
<< "elyrics.net"
<< "lyricsdownload.com"
<< "lyrics.com"
<< "lyricsbay.com"
<< "directlyrics.com"
<< "teksty.org"
<< "tekstowo.pl (Polish translations)"
<< "vagalume.uol.com.br"
<< "vagalume.uol.com.br (Portuguese translations)"
<< "darklyrics.com";
QVariant saved_order = s.value("search_order", default_order);
for (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;
for (SongInfoProvider* provider : ordered_providers) {
provider->set_enabled(true);
qobject_cast<UltimateLyricsProvider*>(provider)->set_relevance(relevance--);
}
// Any lyric providers we don't have in ordered_providers are considered
// disabled
for (SongInfoProvider* provider : fetcher_->providers()) {
if (qobject_cast<UltimateLyricsProvider*>(provider) &&
!ordered_providers.contains(provider)) {
provider->set_enabled(false);
}
}
SongInfoBase::ReloadSettings();
}
SongInfoProvider* SongInfoView::ProviderByName(const QString& name) const {
for (SongInfoProvider* provider : fetcher_->providers()) {
if (UltimateLyricsProvider* lyrics =
qobject_cast<UltimateLyricsProvider*>(provider)) {
if (lyrics->name() == name) return provider;
}
}
return nullptr;
}
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();
}
} // namespace
QList<const UltimateLyricsProvider*> SongInfoView::lyric_providers() const {
QList<const UltimateLyricsProvider*> ret;
for (SongInfoProvider* provider : fetcher_->providers()) {
if (UltimateLyricsProvider* lyrics =
qobject_cast<UltimateLyricsProvider*>(provider)) {
ret << lyrics;
}
}
std::sort(ret.begin(), ret.end(), CompareLyricProviders);
return ret;
}