aboutsummaryrefslogtreecommitdiffstats
path: root/src/command.c
diff options
context:
space:
mode:
authorMax Kellermann <max@duempel.org>2012-02-09 23:52:51 +0100
committerMax Kellermann <max@duempel.org>2012-02-09 23:55:34 +0100
commitb9673fc521c453f8729544541ba48fcafefcf4e9 (patch)
tree18136164865bdf238900065aa2ee6d4d520f3d63 /src/command.c
parentb0ea3f42619d4d831830502f12340105937bf533 (diff)
downloadmpd-b9673fc521c453f8729544541ba48fcafefcf4e9.tar.gz
mpd-b9673fc521c453f8729544541ba48fcafefcf4e9.tar.xz
mpd-b9673fc521c453f8729544541ba48fcafefcf4e9.zip
command: add optional range parameter to "load"
Diffstat (limited to '')
-rw-r--r--src/command.c17
1 files changed, 13 insertions, 4 deletions
diff --git a/src/command.c b/src/command.c
index 1d26acd6b..2737c34e9 100644
--- a/src/command.c
+++ b/src/command.c
@@ -796,12 +796,21 @@ handle_save(struct client *client,
}
static enum command_return
-handle_load(struct client *client, G_GNUC_UNUSED int argc, char *argv[])
+handle_load(struct client *client, int argc, char *argv[])
{
+ unsigned start_index, end_index;
+
+ if (argc < 3) {
+ start_index = 0;
+ end_index = G_MAXUINT;
+ } else if (!check_range(client, &start_index, &end_index,
+ argv[2], need_range))
+ return COMMAND_RETURN_ERROR;
+
enum playlist_result result;
result = playlist_open_into_queue(argv[1],
- 0, G_MAXUINT,
+ start_index, end_index,
&g_playlist,
client->player_control, true);
if (result != PLAYLIST_RESULT_NO_SUCH_LIST)
@@ -809,7 +818,7 @@ handle_load(struct client *client, G_GNUC_UNUSED int argc, char *argv[])
GError *error = NULL;
return playlist_load_spl(&g_playlist, client->player_control,
- argv[1], 0, G_MAXUINT,
+ argv[1], start_index, end_index,
&error)
? COMMAND_RETURN_OK
: print_error(client, error);
@@ -2140,7 +2149,7 @@ static const struct command commands[] = {
{ "listplaylist", PERMISSION_READ, 1, 1, handle_listplaylist },
{ "listplaylistinfo", PERMISSION_READ, 1, 1, handle_listplaylistinfo },
{ "listplaylists", PERMISSION_READ, 0, 0, handle_listplaylists },
- { "load", PERMISSION_ADD, 1, 1, handle_load },
+ { "load", PERMISSION_ADD, 1, 2, handle_load },
{ "lsinfo", PERMISSION_READ, 0, 1, handle_lsinfo },
{ "mixrampdb", PERMISSION_CONTROL, 1, 1, handle_mixrampdb },
{ "mixrampdelay", PERMISSION_CONTROL, 1, 1, handle_mixrampdelay },