command: "load" supports remote playlists (m3u, xspf, lastfm://)
This patch integrates the playlist plugin API to the MPD core. We'll be able to do much more in the future with that API, that's just the beginning.
This commit is contained in:
parent
319149254d
commit
a93ffdd1be
@ -138,6 +138,7 @@ mpd_headers = \
|
|||||||
src/playlist_state.h \
|
src/playlist_state.h \
|
||||||
src/playlist_plugin.h \
|
src/playlist_plugin.h \
|
||||||
src/playlist_list.h \
|
src/playlist_list.h \
|
||||||
|
src/playlist_queue.h \
|
||||||
src/playlist/m3u_playlist_plugin.h \
|
src/playlist/m3u_playlist_plugin.h \
|
||||||
src/playlist/xspf_playlist_plugin.h \
|
src/playlist/xspf_playlist_plugin.h \
|
||||||
src/playlist/lastfm_playlist_plugin.h \
|
src/playlist/lastfm_playlist_plugin.h \
|
||||||
@ -260,6 +261,7 @@ src_mpd_SOURCES = \
|
|||||||
src/playlist_print.c \
|
src/playlist_print.c \
|
||||||
src/playlist_save.c \
|
src/playlist_save.c \
|
||||||
src/playlist_state.c \
|
src/playlist_state.c \
|
||||||
|
src/playlist_queue.c \
|
||||||
src/queue.c \
|
src/queue.c \
|
||||||
src/queue_print.c \
|
src/queue_print.c \
|
||||||
src/queue_save.c \
|
src/queue_save.c \
|
||||||
|
1
NEWS
1
NEWS
@ -7,6 +7,7 @@ ver 0.16 (20??/??/??)
|
|||||||
- range support for "delete"
|
- range support for "delete"
|
||||||
- "previous" really plays the previous song
|
- "previous" really plays the previous song
|
||||||
- "addid" with negative position is deprecated
|
- "addid" with negative position is deprecated
|
||||||
|
- "load" supports remote playlists (m3u, xspf, lastfm://)
|
||||||
* input:
|
* input:
|
||||||
- lastfm: use metadata
|
- lastfm: use metadata
|
||||||
* tags:
|
* tags:
|
||||||
|
@ -22,6 +22,7 @@
|
|||||||
#include "playlist.h"
|
#include "playlist.h"
|
||||||
#include "playlist_print.h"
|
#include "playlist_print.h"
|
||||||
#include "playlist_save.h"
|
#include "playlist_save.h"
|
||||||
|
#include "playlist_queue.h"
|
||||||
#include "queue_print.h"
|
#include "queue_print.h"
|
||||||
#include "ls.h"
|
#include "ls.h"
|
||||||
#include "uri.h"
|
#include "uri.h"
|
||||||
@ -707,6 +708,10 @@ handle_load(struct client *client, G_GNUC_UNUSED int argc, char *argv[])
|
|||||||
{
|
{
|
||||||
enum playlist_result result;
|
enum playlist_result result;
|
||||||
|
|
||||||
|
result = playlist_open_into_queue(argv[1], &g_playlist);
|
||||||
|
if (result != PLAYLIST_RESULT_NO_SUCH_LIST)
|
||||||
|
return result;
|
||||||
|
|
||||||
result = playlist_load_spl(&g_playlist, argv[1]);
|
result = playlist_load_spl(&g_playlist, argv[1]);
|
||||||
return print_playlist_result(client, result);
|
return print_playlist_result(client, result);
|
||||||
}
|
}
|
||||||
|
94
src/playlist_queue.c
Normal file
94
src/playlist_queue.c
Normal file
@ -0,0 +1,94 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2003-2009 The Music Player Daemon Project
|
||||||
|
* http://www.musicpd.org
|
||||||
|
*
|
||||||
|
* This program 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 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program 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 this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "playlist_queue.h"
|
||||||
|
#include "playlist_list.h"
|
||||||
|
#include "playlist_plugin.h"
|
||||||
|
#include "song.h"
|
||||||
|
#include "uri.h"
|
||||||
|
#include "ls.h"
|
||||||
|
#include "input_stream.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Determins if it's allowed to add this song to the playlist. For
|
||||||
|
* safety reasons, we disallow local files.
|
||||||
|
*/
|
||||||
|
static inline bool
|
||||||
|
accept_song(const struct song *song)
|
||||||
|
{
|
||||||
|
return !song_is_file(song) && uri_has_scheme(song->uri) &&
|
||||||
|
uri_supported_scheme(song->uri);
|
||||||
|
}
|
||||||
|
|
||||||
|
enum playlist_result
|
||||||
|
playlist_load_into_queue(struct playlist_provider *source,
|
||||||
|
struct playlist *dest)
|
||||||
|
{
|
||||||
|
enum playlist_result result;
|
||||||
|
struct song *song;
|
||||||
|
|
||||||
|
while ((song = playlist_plugin_read(source)) != NULL) {
|
||||||
|
if (!accept_song(song)) {
|
||||||
|
song_free(song);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
result = playlist_append_song(dest, song, NULL);
|
||||||
|
if (result != PLAYLIST_RESULT_SUCCESS) {
|
||||||
|
song_free(song);
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return PLAYLIST_RESULT_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
|
enum playlist_result
|
||||||
|
playlist_open_into_queue(const char *uri, struct playlist *dest)
|
||||||
|
{
|
||||||
|
struct playlist_provider *playlist;
|
||||||
|
bool stream = false;
|
||||||
|
struct input_stream is;
|
||||||
|
enum playlist_result result;
|
||||||
|
|
||||||
|
if (!uri_has_scheme(uri))
|
||||||
|
/* don't allow local playlist files for now */
|
||||||
|
return PLAYLIST_RESULT_NO_SUCH_LIST;
|
||||||
|
|
||||||
|
playlist = playlist_list_open_uri(uri);
|
||||||
|
if (playlist == NULL) {
|
||||||
|
stream = input_stream_open(&is, uri);
|
||||||
|
if (!stream)
|
||||||
|
return PLAYLIST_RESULT_NO_SUCH_LIST;
|
||||||
|
|
||||||
|
playlist = playlist_list_open_stream(&is, uri);
|
||||||
|
if (playlist == NULL) {
|
||||||
|
input_stream_close(&is);
|
||||||
|
return PLAYLIST_RESULT_NO_SUCH_LIST;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
result = playlist_load_into_queue(playlist, dest);
|
||||||
|
playlist_plugin_close(playlist);
|
||||||
|
|
||||||
|
if (stream)
|
||||||
|
input_stream_close(&is);
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
48
src/playlist_queue.h
Normal file
48
src/playlist_queue.h
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2003-2009 The Music Player Daemon Project
|
||||||
|
* http://www.musicpd.org
|
||||||
|
*
|
||||||
|
* This program 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 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program 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 this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*! \file
|
||||||
|
* \brief Glue between playlist plugin and the play queue
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef MPD_PLAYLIST_QUEUE_H
|
||||||
|
#define MPD_PLAYLIST_QUEUE_H
|
||||||
|
|
||||||
|
#include "playlist.h"
|
||||||
|
|
||||||
|
struct playlist_provider;
|
||||||
|
struct playlist;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Loads the contents of a playlist and append it to the specified
|
||||||
|
* play queue.
|
||||||
|
*/
|
||||||
|
enum playlist_result
|
||||||
|
playlist_load_into_queue(struct playlist_provider *source,
|
||||||
|
struct playlist *dest);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Opens a playlist with a playlist plugin and append to the specified
|
||||||
|
* play queue.
|
||||||
|
*/
|
||||||
|
enum playlist_result
|
||||||
|
playlist_open_into_queue(const char *uri, struct playlist *dest);
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue
Block a user