playlist.h 6.73 KB
Newer Older
1
/*
Max Kellermann's avatar
Max Kellermann committed
2
 * Copyright (C) 2003-2011 The Music Player Daemon Project
3
 * http://www.musicpd.org
Warren Dukes's avatar
Warren Dukes committed
4 5 6 7 8 9 10 11 12 13
 *
 * 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.
14 15 16 17
 *
 * 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.
Warren Dukes's avatar
Warren Dukes committed
18 19
 */

20 21
#ifndef MPD_PLAYLIST_H
#define MPD_PLAYLIST_H
Warren Dukes's avatar
Warren Dukes committed
22

23
#include "queue.h"
24
#include "playlist_error.h"
Warren Dukes's avatar
Warren Dukes committed
25

26
#include <stdbool.h>
27

28 29
struct player_control;

30
struct playlist {
31 32 33
	/**
	 * The song queue - it contains the "real" playlist.
	 */
34 35
	struct queue queue;

36 37 38 39 40 41
	/**
	 * This value is true if the player is currently playing (or
	 * should be playing).
	 */
	bool playing;

42 43 44 45 46 47 48 49 50 51 52 53 54 55
	/**
	 * If true, then any error is fatal; if false, MPD will
	 * attempt to play the next song on non-fatal errors.  During
	 * seeking, this flag is set.
	 */
	bool stop_on_error;

	/**
	 * Number of errors since playback was started.  If this
	 * number exceeds the length of the playlist, MPD gives up,
	 * because all songs have been tried.
	 */
	unsigned error_count;

56 57 58 59 60
	/**
	 * The "current song pointer".  This is the song which is
	 * played when we get the "play" command.  It is also the song
	 * which is currently being played.
	 */
61
	int current;
62 63 64

	/**
	 * The "next" song to be played, when the current one
65 66 67 68
	 * finishes.  The decoder thread may start decoding and
	 * buffering it, while the "current" song is still playing.
	 *
	 * This variable is only valid if #playing is true.
69
	 */
70
	int queued;
71
};
72

73 74 75
/** the global playlist object */
extern struct playlist g_playlist;

Max Kellermann's avatar
Max Kellermann committed
76 77
void
playlist_global_init(void);
Warren Dukes's avatar
Warren Dukes committed
78

Max Kellermann's avatar
Max Kellermann committed
79 80
void
playlist_global_finish(void);
Warren Dukes's avatar
Warren Dukes committed
81

82 83 84 85 86 87 88 89 90
void
playlist_init(struct playlist *playlist);

void
playlist_finish(struct playlist *playlist);

void
playlist_tag_changed(struct playlist *playlist);

91 92 93
/**
 * Returns the "queue" object of the global playlist instance.
 */
94 95 96 97 98
static inline const struct queue *
playlist_get_queue(const struct playlist *playlist)
{
	return &playlist->queue;
}
99

100
void
101
playlist_clear(struct playlist *playlist, struct player_control *pc);
Warren Dukes's avatar
Warren Dukes committed
102

103
/**
104 105 106
 * Appends a local file (outside the music database) to the playlist.
 *
 * Note: the caller is responsible for checking permissions.
107 108
 */
enum playlist_result
109
playlist_append_file(struct playlist *playlist, struct player_control *pc,
110
		     const char *path_fs, unsigned *added_id);
111

112
enum playlist_result
113 114
playlist_append_uri(struct playlist *playlist, struct player_control *pc,
		    const char *file, unsigned *added_id);
Warren Dukes's avatar
Warren Dukes committed
115

116
enum playlist_result
117
playlist_append_song(struct playlist *playlist, struct player_control *pc,
118
		  struct song *song, unsigned *added_id);
Warren Dukes's avatar
Warren Dukes committed
119

120
enum playlist_result
121 122
playlist_delete(struct playlist *playlist, struct player_control *pc,
		unsigned song);
Warren Dukes's avatar
Warren Dukes committed
123

124 125 126 127 128 129 130
/**
 * Deletes a range of songs from the playlist.
 *
 * @param start the position of the first song to delete
 * @param end the position after the last song to delete
 */
enum playlist_result
131 132
playlist_delete_range(struct playlist *playlist, struct player_control *pc,
		      unsigned start, unsigned end);
133

134
enum playlist_result
135 136
playlist_delete_id(struct playlist *playlist, struct player_control *pc,
		   unsigned song);
137

138
void
139
playlist_stop(struct playlist *playlist, struct player_control *pc);
Warren Dukes's avatar
Warren Dukes committed
140

141
enum playlist_result
142 143
playlist_play(struct playlist *playlist, struct player_control *pc,
	      int song);
Warren Dukes's avatar
Warren Dukes committed
144

145
enum playlist_result
146 147
playlist_play_id(struct playlist *playlist, struct player_control *pc,
		 int song);
148

149
void
150
playlist_next(struct playlist *playlist, struct player_control *pc);
Warren Dukes's avatar
Warren Dukes committed
151

152
void
153
playlist_sync(struct playlist *playlist, struct player_control *pc);
Warren Dukes's avatar
Warren Dukes committed
154

155
void
156
playlist_previous(struct playlist *playlist, struct player_control *pc);
Warren Dukes's avatar
Warren Dukes committed
157

Max Kellermann's avatar
Max Kellermann committed
158
void
159 160
playlist_shuffle(struct playlist *playlist, struct player_control *pc,
		 unsigned start, unsigned end);
Warren Dukes's avatar
Warren Dukes committed
161

162
void
163 164
playlist_delete_song(struct playlist *playlist, struct player_control *pc,
		     const struct song *song);
Warren Dukes's avatar
Warren Dukes committed
165

166
enum playlist_result
167 168
playlist_move_range(struct playlist *playlist, struct player_control *pc,
		    unsigned start, unsigned end, int to);
Warren Dukes's avatar
Warren Dukes committed
169

170
enum playlist_result
171 172
playlist_move_id(struct playlist *playlist, struct player_control *pc,
		 unsigned id, int to);
173

174
enum playlist_result
175 176
playlist_swap_songs(struct playlist *playlist, struct player_control *pc,
		    unsigned song1, unsigned song2);
Warren Dukes's avatar
Warren Dukes committed
177

178
enum playlist_result
179 180
playlist_swap_songs_id(struct playlist *playlist, struct player_control *pc,
		       unsigned id1, unsigned id2);
181

182 183 184 185 186 187 188 189 190
enum playlist_result
playlist_set_priority(struct playlist *playlist, struct player_control *pc,
		      unsigned start_position, unsigned end_position,
		      uint8_t priority);

enum playlist_result
playlist_set_priority_id(struct playlist *playlist, struct player_control *pc,
			 unsigned song_id, uint8_t priority);

191
bool
192
playlist_get_repeat(const struct playlist *playlist);
Warren Dukes's avatar
Warren Dukes committed
193

194
void
195 196
playlist_set_repeat(struct playlist *playlist, struct player_control *pc,
		    bool status);
Warren Dukes's avatar
Warren Dukes committed
197

198
bool
199
playlist_get_random(const struct playlist *playlist);
Warren Dukes's avatar
Warren Dukes committed
200

201
void
202 203
playlist_set_random(struct playlist *playlist, struct player_control *pc,
		    bool status);
Warren Dukes's avatar
Warren Dukes committed
204

205
bool
206
playlist_get_single(const struct playlist *playlist);
207

208
void
209 210
playlist_set_single(struct playlist *playlist, struct player_control *pc,
		    bool status);
211

212
bool
213
playlist_get_consume(const struct playlist *playlist);
214

215 216
void
playlist_set_consume(struct playlist *playlist, bool status);
217

218 219
int
playlist_get_current_song(const struct playlist *playlist);
Warren Dukes's avatar
Warren Dukes committed
220

221 222
int
playlist_get_next_song(const struct playlist *playlist);
223

224
unsigned
225
playlist_get_song_id(const struct playlist *playlist, unsigned song);
226

227 228
int
playlist_get_length(const struct playlist *playlist);
Warren Dukes's avatar
Warren Dukes committed
229

230
unsigned long
231
playlist_get_version(const struct playlist *playlist);
Warren Dukes's avatar
Warren Dukes committed
232

233
enum playlist_result
234 235
playlist_seek_song(struct playlist *playlist, struct player_control *pc,
		   unsigned song, float seek_time);
Warren Dukes's avatar
Warren Dukes committed
236

237
enum playlist_result
238
playlist_seek_song_id(struct playlist *playlist, struct player_control *pc,
239
		       unsigned id, float seek_time);
240

241 242 243 244 245 246 247 248 249 250 251 252
/**
 * Seek within the current song.  Fails if MPD is not currently
 * playing.
 *
 * @param time the time in seconds
 * @param relative if true, then the specified time is relative to the
 * current position
 */
enum playlist_result
playlist_seek_current(struct playlist *playlist, struct player_control *pc,
		      float seek_time, bool relative);

253 254
void
playlist_increment_version_all(struct playlist *playlist);
255

Warren Dukes's avatar
Warren Dukes committed
256
#endif