2023-03-06 14:42:04 +01:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
// Copyright The Music Player Daemon Project
|
2009-10-13 18:53:33 +02:00
|
|
|
|
2009-11-12 09:12:38 +01:00
|
|
|
#include "config.h"
|
2019-02-13 21:55:15 +01:00
|
|
|
#include "LocateUri.hxx"
|
2013-01-02 18:38:32 +01:00
|
|
|
#include "PlaylistQueue.hxx"
|
|
|
|
#include "PlaylistAny.hxx"
|
|
|
|
#include "PlaylistSong.hxx"
|
2016-03-01 22:08:13 +01:00
|
|
|
#include "PlaylistError.hxx"
|
2014-02-27 17:12:42 +01:00
|
|
|
#include "queue/Playlist.hxx"
|
2013-09-05 09:37:54 +02:00
|
|
|
#include "SongEnumerator.hxx"
|
2018-08-02 13:45:43 +02:00
|
|
|
#include "song/DetachedSong.hxx"
|
2024-05-15 19:58:12 +02:00
|
|
|
#include "input/Error.hxx"
|
2014-02-07 20:27:24 +01:00
|
|
|
#include "thread/Mutex.hxx"
|
2013-10-21 10:26:53 +02:00
|
|
|
#include "fs/Traits.hxx"
|
2022-11-26 08:28:10 -08:00
|
|
|
#include "Log.hxx"
|
2013-10-17 09:43:55 +02:00
|
|
|
|
2014-02-07 20:22:26 +01:00
|
|
|
#ifdef ENABLE_DATABASE
|
|
|
|
#include "SongLoader.hxx"
|
|
|
|
#endif
|
|
|
|
|
2016-02-28 10:58:50 +01:00
|
|
|
#include <memory>
|
|
|
|
|
2016-02-28 10:51:07 +01:00
|
|
|
void
|
2013-09-05 09:37:54 +02:00
|
|
|
playlist_load_into_queue(const char *uri, SongEnumerator &e,
|
2012-02-09 23:44:33 +01:00
|
|
|
unsigned start_index, unsigned end_index,
|
2013-10-28 10:12:21 +01:00
|
|
|
playlist &dest, PlayerControl &pc,
|
2016-02-28 10:51:07 +01:00
|
|
|
const SongLoader &loader)
|
2009-10-13 18:53:33 +02:00
|
|
|
{
|
2022-11-26 08:28:10 -08:00
|
|
|
const unsigned max_log_msgs = 8;
|
|
|
|
|
2020-03-13 19:37:59 +01:00
|
|
|
const auto base_uri = uri != nullptr
|
2013-12-05 03:53:43 +06:00
|
|
|
? PathTraitsUTF8::GetParent(uri)
|
2020-03-13 19:37:59 +01:00
|
|
|
: ".";
|
2009-10-13 18:53:33 +02:00
|
|
|
|
2016-02-07 08:23:30 +01:00
|
|
|
std::unique_ptr<DetachedSong> song;
|
2022-11-26 08:28:10 -08:00
|
|
|
for (unsigned i = 0, failures = 0;
|
2013-10-02 08:13:28 +02:00
|
|
|
i < end_index && (song = e.NextSong()) != nullptr;
|
2012-02-09 23:44:33 +01:00
|
|
|
++i) {
|
|
|
|
if (i < start_index) {
|
|
|
|
/* skip songs before the start index */
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2020-03-13 19:37:59 +01:00
|
|
|
if (!playlist_check_translate_song(*song, base_uri,
|
2014-02-02 14:37:52 +01:00
|
|
|
loader)) {
|
2022-11-26 08:28:10 -08:00
|
|
|
failures += 1;
|
|
|
|
if (failures < max_log_msgs) {
|
2024-04-16 11:06:34 +02:00
|
|
|
FmtError(playlist_domain, "Failed to load {:?}.", song->GetURI());
|
2022-11-26 08:28:10 -08:00
|
|
|
} else if (failures == max_log_msgs) {
|
|
|
|
LogError(playlist_domain, "Further errors for this playlist will not be logged.");
|
|
|
|
}
|
2009-10-13 18:53:33 +02:00
|
|
|
continue;
|
2014-01-20 23:48:46 +01:00
|
|
|
}
|
2009-10-13 18:53:33 +02:00
|
|
|
|
2016-02-28 10:51:07 +01:00
|
|
|
dest.AppendSong(pc, std::move(*song));
|
2009-10-13 18:53:33 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-02-28 10:51:07 +01:00
|
|
|
void
|
2019-02-13 21:55:15 +01:00
|
|
|
playlist_open_into_queue(const LocatedUri &uri,
|
2012-02-09 23:44:33 +01:00
|
|
|
unsigned start_index, unsigned end_index,
|
2013-10-28 10:12:21 +01:00
|
|
|
playlist &dest, PlayerControl &pc,
|
2016-02-28 10:51:07 +01:00
|
|
|
const SongLoader &loader)
|
2024-05-15 19:58:12 +02:00
|
|
|
try {
|
2013-01-27 17:20:50 +01:00
|
|
|
Mutex mutex;
|
2011-09-14 21:46:41 +02:00
|
|
|
|
2018-01-20 20:14:19 +01:00
|
|
|
auto playlist = playlist_open_any(uri,
|
2014-02-07 20:22:26 +01:00
|
|
|
#ifdef ENABLE_DATABASE
|
2018-01-20 20:14:19 +01:00
|
|
|
loader.GetStorage(),
|
2014-02-07 20:22:26 +01:00
|
|
|
#endif
|
2018-06-22 19:37:18 +02:00
|
|
|
mutex);
|
2016-02-28 10:51:07 +01:00
|
|
|
if (playlist == nullptr)
|
|
|
|
throw PlaylistError::NoSuchList();
|
2010-06-01 09:10:58 +02:00
|
|
|
|
2019-02-13 21:55:15 +01:00
|
|
|
playlist_load_into_queue(uri.canonical_uri, *playlist,
|
2016-02-28 10:51:07 +01:00
|
|
|
start_index, end_index,
|
|
|
|
dest, pc, loader);
|
2024-05-15 19:58:12 +02:00
|
|
|
} catch (...) {
|
|
|
|
if (IsFileNotFound(std::current_exception()))
|
|
|
|
throw PlaylistError::NoSuchList();
|
|
|
|
|
|
|
|
throw;
|
2009-11-06 01:07:42 +01:00
|
|
|
}
|