db/update/Playlist: move code to another UpdatePlaylistFile() method

This commit is contained in:
Max Kellermann 2021-10-14 11:35:35 +02:00
parent cd5c1f3f45
commit 1b8c94d6b9
2 changed files with 42 additions and 32 deletions

View File

@ -35,7 +35,43 @@
#include "util/StringFormat.hxx" #include "util/StringFormat.hxx"
#include "Log.hxx" #include "Log.hxx"
void inline void
UpdateWalk::UpdatePlaylistFile(Directory &directory,
SongEnumerator &contents) noexcept
{
unsigned track = 0;
while (true) {
auto song = contents.NextSong();
if (!song)
break;
auto db_song = std::make_unique<Song>(std::move(*song),
directory);
const bool is_absolute =
PathTraitsUTF8::IsAbsoluteOrHasScheme(db_song->filename.c_str());
db_song->target = is_absolute
? db_song->filename
/* prepend "../" to relative paths to go from
the virtual directory (DEVICE_PLAYLIST) to
the containing directory */
: "../" + db_song->filename;
db_song->filename = StringFormat<64>("track%04u",
++track);
{
const ScopeDatabaseLock protect;
if (!is_absolute &&
!directory.TargetExists(db_song->target))
continue;
directory.AddSong(std::move(db_song));
}
}
}
inline void
UpdateWalk::UpdatePlaylistFile(Directory &parent, std::string_view name, UpdateWalk::UpdatePlaylistFile(Directory &parent, std::string_view name,
const StorageFileInfo &info, const StorageFileInfo &info,
const PlaylistPlugin &plugin) noexcept const PlaylistPlugin &plugin) noexcept
@ -63,37 +99,7 @@ UpdateWalk::UpdatePlaylistFile(Directory &parent, std::string_view name,
return; return;
} }
unsigned track = 0; UpdatePlaylistFile(*directory, *e);
while (true) {
auto song = e->NextSong();
if (!song)
break;
auto db_song = std::make_unique<Song>(std::move(*song),
*directory);
const bool is_absolute =
PathTraitsUTF8::IsAbsoluteOrHasScheme(db_song->filename.c_str());
db_song->target = is_absolute
? db_song->filename
/* prepend "../" to relative paths to
go from the virtual directory
(DEVICE_PLAYLIST) to the containing
directory */
: "../" + db_song->filename;
db_song->filename = StringFormat<64>("track%04u",
++track);
{
const ScopeDatabaseLock protect;
if (!is_absolute &&
!directory->TargetExists(db_song->target))
continue;
directory->AddSong(std::move(db_song));
}
}
if (directory->IsEmpty()) if (directory->IsEmpty())
editor.LockDeleteDirectory(directory); editor.LockDeleteDirectory(directory);

View File

@ -31,6 +31,7 @@ struct StorageFileInfo;
struct Directory; struct Directory;
struct ArchivePlugin; struct ArchivePlugin;
struct PlaylistPlugin; struct PlaylistPlugin;
class SongEnumerator;
class ArchiveFile; class ArchiveFile;
class Storage; class Storage;
class ExcludeList; class ExcludeList;
@ -125,6 +126,9 @@ private:
} }
#endif #endif
void UpdatePlaylistFile(Directory &directory,
SongEnumerator &contents) noexcept;
void UpdatePlaylistFile(Directory &parent, std::string_view name, void UpdatePlaylistFile(Directory &parent, std::string_view name,
const StorageFileInfo &info, const StorageFileInfo &info,
const PlaylistPlugin &plugin) noexcept; const PlaylistPlugin &plugin) noexcept;