1
0
mirror of https://github.com/clementine-player/Clementine synced 2025-01-06 23:31:34 +01:00

Load all the metadata for the first song, so the duration will appear properly when it starts playing.

This commit is contained in:
David Sansome 2014-05-11 17:02:04 +10:00
parent f52e48c956
commit 4e9a7ca7f3

View File

@ -119,15 +119,21 @@ void SongLoaderInserter::InsertSongs() {
} }
void SongLoaderInserter::AsyncLoad() { void SongLoaderInserter::AsyncLoad() {
// First, quick load raw songs. // First, quick load raw songs.
int async_progress = 0; int async_progress = 0;
int async_load_id = task_manager_->StartTask(tr("Loading tracks")); int async_load_id = task_manager_->StartTask(tr("Loading tracks"));
task_manager_->SetTaskProgress(async_load_id, async_progress, task_manager_->SetTaskProgress(async_load_id, async_progress,
pending_.count()); pending_.count());
for (SongLoader* loader : pending_) { for (int i = 0; i < pending_.count(); ++i) {
SongLoader* loader = pending_[i];
loader->LoadFilenamesBlocking(); loader->LoadFilenamesBlocking();
task_manager_->SetTaskProgress(async_load_id, ++async_progress); task_manager_->SetTaskProgress(async_load_id, ++async_progress);
if (i == 0) {
// Load everything from the first song. It'll start playing as soon as
// we emit PreloadFinished, so it needs to have the duration set to show
// properly in the UI.
loader->LoadMetadataBlocking();
}
songs_ << loader->songs(); songs_ << loader->songs();
} }
task_manager_->SetTaskFinished(async_load_id); task_manager_->SetTaskFinished(async_load_id);
@ -138,8 +144,12 @@ void SongLoaderInserter::AsyncLoad() {
async_load_id = task_manager_->StartTask(tr("Loading tracks info")); async_load_id = task_manager_->StartTask(tr("Loading tracks info"));
task_manager_->SetTaskProgress(async_load_id, async_progress, songs_.count()); task_manager_->SetTaskProgress(async_load_id, async_progress, songs_.count());
SongList songs; SongList songs;
for (SongLoader* loader : pending_) { for (int i = 0; i < pending_.count(); ++i) {
loader->LoadMetadataBlocking(); SongLoader* loader = pending_[i];
if (i != 0) {
// We already did this earlier for the first song.
loader->LoadMetadataBlocking();
}
songs << loader->songs(); songs << loader->songs();
task_manager_->SetTaskProgress(async_load_id, songs.count()); task_manager_->SetTaskProgress(async_load_id, songs.count());
} }