Merge branch 'feature/playlist' of git://github.com/miccoli/MPD

This commit is contained in:
Max Kellermann 2019-02-27 13:48:02 +01:00
commit 713c1f2ba9
9 changed files with 45 additions and 15 deletions

2
NEWS
View File

@ -1,4 +1,6 @@
ver 0.21.6 (not yet released) ver 0.21.6 (not yet released)
* protocol
- allow loading playlists specified as absolute filesystem paths
* input * input
- cdio_paranoia: fix build failure due to missing #include - cdio_paranoia: fix build failure due to missing #include
* support abstract sockets on Linux * support abstract sockets on Linux

View File

@ -714,7 +714,9 @@ and without the `.m3u` suffix).
Some of the commands described in this section can be used to Some of the commands described in this section can be used to
run playlist plugins instead of the hard-coded simple run playlist plugins instead of the hard-coded simple
`m3u` parser. They can access playlists in `m3u` parser. They can access playlists in
the music directory (relative path including the suffix) or the music directory (relative path including the suffix),
playlists in arbitrary location (absolute path including the suffix;
allowed only for clients that are connected via UNIX domain socket), or
remote playlists (absolute URI with a supported scheme). remote playlists (absolute URI with a supported scheme).
:command:`listplaylist {NAME}` :command:`listplaylist {NAME}`

View File

@ -38,6 +38,7 @@
#include "util/UriUtil.hxx" #include "util/UriUtil.hxx"
#include "util/ConstBuffer.hxx" #include "util/ConstBuffer.hxx"
#include "util/ChronoUtil.hxx" #include "util/ChronoUtil.hxx"
#include "LocateUri.hxx"
bool bool
playlist_commands_available() noexcept playlist_commands_available() noexcept
@ -66,12 +67,17 @@ handle_save(Client &client, Request args, gcc_unused Response &r)
CommandResult CommandResult
handle_load(Client &client, Request args, gcc_unused Response &r) handle_load(Client &client, Request args, gcc_unused Response &r)
{ {
const auto uri = LocateUri(args.front(), &client
#ifdef ENABLE_DATABASE
, nullptr
#endif
);
RangeArg range = args.ParseOptional(1, RangeArg::All()); RangeArg range = args.ParseOptional(1, RangeArg::All());
const ScopeBulkEdit bulk_edit(client.GetPartition()); const ScopeBulkEdit bulk_edit(client.GetPartition());
const SongLoader loader(client); const SongLoader loader(client);
playlist_open_into_queue(args.front(), playlist_open_into_queue(uri,
range.start, range.end, range.start, range.end,
client.GetPlaylist(), client.GetPlaylist(),
client.GetPlayerControl(), loader); client.GetPlayerControl(), loader);
@ -81,7 +87,11 @@ handle_load(Client &client, Request args, gcc_unused Response &r)
CommandResult CommandResult
handle_listplaylist(Client &client, Request args, Response &r) handle_listplaylist(Client &client, Request args, Response &r)
{ {
const char *const name = args.front(); const auto name = LocateUri(args.front(), &client
#ifdef ENABLE_DATABASE
, nullptr
#endif
);
if (playlist_file_print(r, client.GetPartition(), SongLoader(client), if (playlist_file_print(r, client.GetPartition(), SongLoader(client),
name, false)) name, false))
@ -93,7 +103,11 @@ handle_listplaylist(Client &client, Request args, Response &r)
CommandResult CommandResult
handle_listplaylistinfo(Client &client, Request args, Response &r) handle_listplaylistinfo(Client &client, Request args, Response &r)
{ {
const char *const name = args.front(); const auto name = LocateUri(args.front(), &client
#ifdef ENABLE_DATABASE
, nullptr
#endif
);
if (playlist_file_print(r, client.GetPartition(), SongLoader(client), if (playlist_file_print(r, client.GetPartition(), SongLoader(client),
name, true)) name, true))

View File

@ -17,6 +17,7 @@
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/ */
#include "LocateUri.hxx"
#include "PlaylistAny.hxx" #include "PlaylistAny.hxx"
#include "PlaylistStream.hxx" #include "PlaylistStream.hxx"
#include "PlaylistMapper.hxx" #include "PlaylistMapper.hxx"
@ -25,17 +26,26 @@
#include "config.h" #include "config.h"
std::unique_ptr<SongEnumerator> std::unique_ptr<SongEnumerator>
playlist_open_any(const char *uri, playlist_open_any(const LocatedUri &located_uri,
#ifdef ENABLE_DATABASE #ifdef ENABLE_DATABASE
const Storage *storage, const Storage *storage,
#endif #endif
Mutex &mutex) Mutex &mutex)
{ {
return uri_has_scheme(uri) switch (located_uri.type) {
? playlist_open_remote(uri, mutex) case LocatedUri::Type::ABSOLUTE:
: playlist_mapper_open(uri, return playlist_open_remote(located_uri.canonical_uri, mutex);
case LocatedUri::Type::PATH:
return playlist_open_path(located_uri.path, mutex);
case LocatedUri::Type::RELATIVE:
return playlist_mapper_open(located_uri.canonical_uri,
#ifdef ENABLE_DATABASE #ifdef ENABLE_DATABASE
storage, storage,
#endif #endif
mutex); mutex);
} }
gcc_unreachable();
}

View File

@ -34,7 +34,7 @@ class Storage;
* music or playlist directory. * music or playlist directory.
*/ */
std::unique_ptr<SongEnumerator> std::unique_ptr<SongEnumerator>
playlist_open_any(const char *uri, playlist_open_any(const LocatedUri &located_uri,
#ifdef ENABLE_DATABASE #ifdef ENABLE_DATABASE
const Storage *storage, const Storage *storage,
#endif #endif

View File

@ -18,6 +18,7 @@
*/ */
#include "config.h" #include "config.h"
#include "LocateUri.hxx"
#include "PlaylistQueue.hxx" #include "PlaylistQueue.hxx"
#include "PlaylistAny.hxx" #include "PlaylistAny.hxx"
#include "PlaylistSong.hxx" #include "PlaylistSong.hxx"
@ -63,7 +64,7 @@ playlist_load_into_queue(const char *uri, SongEnumerator &e,
} }
void void
playlist_open_into_queue(const char *uri, playlist_open_into_queue(const LocatedUri &uri,
unsigned start_index, unsigned end_index, unsigned start_index, unsigned end_index,
playlist &dest, PlayerControl &pc, playlist &dest, PlayerControl &pc,
const SongLoader &loader) const SongLoader &loader)
@ -78,7 +79,7 @@ playlist_open_into_queue(const char *uri,
if (playlist == nullptr) if (playlist == nullptr)
throw PlaylistError::NoSuchList(); throw PlaylistError::NoSuchList();
playlist_load_into_queue(uri, *playlist, playlist_load_into_queue(uri.canonical_uri, *playlist,
start_index, end_index, start_index, end_index,
dest, pc, loader); dest, pc, loader);
} }

View File

@ -49,7 +49,7 @@ playlist_load_into_queue(const char *uri, SongEnumerator &e,
* play queue. * play queue.
*/ */
void void
playlist_open_into_queue(const char *uri, playlist_open_into_queue(const LocatedUri &uri,
unsigned start_index, unsigned end_index, unsigned start_index, unsigned end_index,
playlist &dest, PlayerControl &pc, playlist &dest, PlayerControl &pc,
const SongLoader &loader); const SongLoader &loader);

View File

@ -18,6 +18,7 @@
*/ */
#include "config.h" #include "config.h"
#include "LocateUri.hxx"
#include "Print.hxx" #include "Print.hxx"
#include "PlaylistAny.hxx" #include "PlaylistAny.hxx"
#include "PlaylistSong.hxx" #include "PlaylistSong.hxx"
@ -55,7 +56,7 @@ playlist_provider_print(Response &r,
bool bool
playlist_file_print(Response &r, Partition &partition, playlist_file_print(Response &r, Partition &partition,
const SongLoader &loader, const SongLoader &loader,
const char *uri, bool detail) const LocatedUri &uri, bool detail)
{ {
Mutex mutex; Mutex mutex;
@ -71,6 +72,6 @@ playlist_file_print(Response &r, Partition &partition,
if (playlist == nullptr) if (playlist == nullptr)
return false; return false;
playlist_provider_print(r, loader, uri, *playlist, detail); playlist_provider_print(r, loader, uri.canonical_uri, *playlist, detail);
return true; return true;
} }

View File

@ -34,6 +34,6 @@ struct Partition;
bool bool
playlist_file_print(Response &r, Partition &partition, playlist_file_print(Response &r, Partition &partition,
const SongLoader &loader, const SongLoader &loader,
const char *uri, bool detail); const LocatedUri &uri, bool detail);
#endif #endif